Überprüfen Sie das maximale Auftreten von Array in einer verschachtelten Funktion mit Antlr4Java

Java-Forum
Anonymous
 Überprüfen Sie das maximale Auftreten von Array in einer verschachtelten Funktion mit Antlr4

Post by Anonymous »

Ich habe die folgende Grammatikdatei zum Parsen verschachtelter Funktionen. < /p>
Grammatik: < /p>

Code: Select all

grammar FunctionTokenizer;

parse     : function* EOF;
function  : ID '(' expr_list? ')';
expr_list : expr (',' expr)*;
expr      : expr subscript | function | STRING | NUMBER | ID;
subscript : '[' expr? ']';

STRING    : '"' ~'"'* '"';
NUMBER    : [0-9]+ ('.' [0-9]+)?;
ID        : [a-zA-Z_] [a-zA-Z_0-9]*;
SPACES    : [ \t\r\n]+ -> skip;
< /code>
Eingabe fällt aus, da sie eine quadratische Klammer aufweist. Ich habe die Regex für Lexer als: < /p>
geändertID        : [a-zA-Z_] [a-zA-Z_0-9\\[\\]]*;
< /code>
, aber ich erhalte einen Fehler. < /p>
Eingabe: < /p>
split(mul(add(input["data"][0]["name"][]["node"],input["data"][0]),input["data"][0]["name"][]["node"][]),",")
Für die obige Eingabe überprüfe ich, welches Argument maximale Klammern entweder [] (leer) oder [0-9] Quadratklammern mit Zahlen hat, die diejenigen mit einzelnen und doppelten Zitaten wie ["1234"] oder ['Data'] . Eingabe ["Daten"] [0] ["Name"] [] ["Node"] [] hat ein maximales Array. />
https://github.com/vikramas/CheckmaxArr ... ree/master

Code: Select all

VisitorImplementation
Klasse:

Code: Select all

public class FunctionValidateVisitorImpl  extends FunctionTokenizerBaseVisitor  {

@Override
public String visitParse(FunctionTokenizerParser.ParseContext ctx) {
ParseTree name = ctx.getChild(2);
String visit = visit(name);
System.err.println("visit1:::::::::::"+visit);
return visit(name);
}

@Override
public String visitFunction(FunctionTokenizerParser.FunctionContext ctx) {
ParseTree name = ctx.getChild(2);
String visit = visit(name);
System.err.println("visit2:::::::::::"+visit);
return visit;
}

@Override
public String visitExpr_list(FunctionTokenizerParser.Expr_listContext ctx) {
String s="";
for (int i = 0; i < ctx.getChildCount(); i+=2) {
if(ctx.getChild(i) instanceof FunctionTokenizerParser.Expr_listContext ) {
String g=visit(ctx.getChild(i));
System.err.println("visit3:::::::::::if "+i+"    "+g);
s=s+g;
}
else {
System.err.println("visit4:::::::::::else  "+i+"    "+ctx.getChild(i).getText());
s=s+ctx.getChild(i).getText();
}
}
return s;
}

public String visitSubscript(FunctionTokenizerParser.SubscriptContext ctx) {
System.err.println("visit5:::::::::::");
String s="";
for (int i = 0; i < ctx.getChildCount(); i++) {
if(ctx.getChild(i) instanceof FunctionTokenizerParser.SubscriptContext) {
String g=visit(ctx.getChild(i));
s=s+g;
}
else {
s=s+ctx.getChild(i).getText();
}
}
return s;
}

@Override
public String visitExpr(FunctionTokenizerParser.ExprContext ctx) {
System.err.println("visit6:::::::::::");
String s="";
for (int i = 0; i < ctx.getChildCount(); i++) {
if(ctx.getChild(i) instanceof TerminalNodeImpl ) {
s=s+ctx.getChild(i).getText();
}
else {
String g=visit(ctx.getChild(i));

s=s+g;
}
}

return s;
}
}
< /code>
Testklasse: < /p>
public class FunctionValidate {

public static void main(String[] args) {
try {
String input = "mul(add(input[\"data\"][0][\"name\"][][\"node\"],input[\"data\"][0]),input[\"data\"][0][\"name\"][][\"node\"][])";
ANTLRInputStream str = new ANTLRInputStream(input);
FunctionTokenizerLexer lexer = new FunctionTokenizerLexer(str);
CommonTokenStream tokens = new CommonTokenStream(lexer);
FunctionTokenizerParser parser = new FunctionTokenizerParser(tokens);
parser.removeErrorListeners(); // remove ConsoleErrorListener
parser.addErrorListener(new VerboseListener());
FunctionContext tree = parser.function();
FunctionValidateVisitorImpl visitor = new FunctionValidateVisitorImpl();
visitor.visit(tree);
System.out.println("-->"+tree.toStringTree( parser ));
AST ast=new AST(tree);
System.out.println( "Improved ParseTree:\n"  + ast.toString() );
JFrame frame = new JFrame("Antlr AST");
JPanel panel = new JPanel();
TreeViewer viewr = new TreeViewer(Arrays.asList(
parser.getRuleNames()),tree);
viewr.setScale(1.5);
panel.add(viewr);
frame.add(panel);
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.setSize(500,500);
frame.setVisible(true);
} catch (Exception e) {
e.printStackTrace();
}
}
}

Die Besucherimplementierung arbeitet für ein Argument, aber wenn ich mehrere Argumente übergeben kann, fehlschlägt es.split(rrr(test(input[\"data\"][0]),input[\"data\"]),input[\"data\"])[]
< /code>
Ausgabe: < /p>
visit4:::::::::::else 0 rrr(test(input["data"][0]),input["data"])
visit4:::::::::::else 2 input["data"]
visit2:::::::::::rrr(test(input["data"][0]),input["data"])input["data"]
< /code>
Nach der Ausdruckslistenmethode wird direkt sonst Schleife ausgeführt, sollte jedoch eine Besuchsmethode aufrufen. Die Instanz der Ausdruckslistenbedingung fällt aus>

Quick Reply

Change Text Case: 
   
  • Similar Topics
    Replies
    Views
    Last post