<eof> antlr4

时间:2018-05-02 08:33:07

标签: java debugging antlr4

我最近遇到了不匹配错误,我想知道是否有人可以查看并查看我的代码中的任何缺陷。

继承我的语法文件:

grammar foo;

program: codeBlock EOF;

codeBlock : 'begin'  statement* 'end';


statement  : print|variableDec|changeValue|ifState;


variableDec : Var ID IS (STRING|NUMBER);


print : Output (STRING|ID);


changeValue : ID IS (ID|NUMBER|STRING);


ifState: IF expressionState block;



block: '{' statement+ '}';




expressionState : (NUMBER|ID|STRING) EXPRESSION (NUMBER|ID|STRING);


EXPRESSION : 
'>'|
'<'|
'=='|
'>='|
'<='
;



IF: 'if';
Var: 'var';
Output : 'output';
IS: '=';
ID : [A-z]+;
NUMBER : [0-9]+ ;
STRING : ["] ( ~["\r\n\\] | '\\' ~[\r\n] )* ["] | ['] ( ~['\r\n\\] |  '\\' ~[\r\n] )* ['];
WS : [ \n\t]+ -> skip;
Comment: '**' ~( '\r' | '\n' )* -> skip;

使用此代码编译后:

begin

var b = 5
var c = 4
var a = "Hello World"

output a

end

我得到了这个输出:

run:
Hello World
line 10:0 mismatched input '<EOF>' expecting 'begin'
BUILD SUCCESSFUL (total time: 0 seconds)

终于来了我的访客班:

public class FooVisitor extends fooBaseVisitor{

private Map<String, Object> variable;

@Override
public Object visitIfState(fooParser.IfStateContext ctx)
{
    //do if statement later... use .clear and .accept functions
    return true;
}

@Override
public Object visitVariableDec(fooParser.VariableDecContext ctx)
{
    String name = ctx.ID(0).getText();
    Object value = null;
    if(ctx.NUMBER() != null)
    {
        value = Integer.parseInt(ctx.NUMBER().getText());

    }
    if(ctx.STRING() != null)
    {
        value = ctx.STRING().getText();
    }

    if(ctx.ID(1) != null)
    {
        value = variable.get(ctx.ID(1).getText());
    }
    return variable.put(name, value);
}

@Override
public Object visitChangeValue(fooParser.ChangeValueContext ctx)
{
   String varName = ctx.ID(0).getText();
    if(ctx.ID(1) != null)
    {



        variable.put(varName, variable.get(ctx.ID(1).getText()));
    }
    if(ctx.STRING() != null)
    {



        variable.put(varName, ctx.STRING().getText());
    }
    if(ctx.NUMBER() != null)
    {



        variable.put(varName, Integer.parseInt(ctx.NUMBER().getText()));
    }

    return null;

}

@Override
public Object visitPrint(fooParser.PrintContext ctx)
{
    String printText = null;
    if(ctx.ID() != null)
    {
       printText = variable.get(ctx.ID().getText()).toString();
       if(variable.get(ctx.ID().getText()) instanceof String)
       {
           printText = printText.replace("\"", "");
       }
    }else
    {
        printText = ctx.STRING().getText();
    }

    System.out.println(printText);
    return printText;
}





/**
 * @param args the command line arguments
 */
public static void main(String[] args) throws IOException {
    fooLexer lexer = new fooLexer(new ANTLRFileStream(args[0]));
    fooParser parser = new fooParser(new CommonTokenStream(lexer));
    ParseTree tree = parser.program();
    FooVisitor vistor = new FooVisitor();
    vistor.visit(tree);

    // Start parsing
    parser.program(); 

}

public FooVisitor() {
    //init the variables
    this.variable = new HashMap<>();
}

}

如果有人在我的代码或语法文件中发现任何缺陷,请指出。感谢。

编辑:添加了访问者类。

1 个答案:

答案 0 :(得分:1)

您正在调用parser.program()两次(main方法的第三行和第八行)。由于第一次调用会消耗所有输入(并且您不会在其间重置输入流),因此解析器的第二次运行将在文件末尾开始并失败。这就是为什么它在第8行期望begin

删除第二个电话,它会正常工作。