我最近遇到了不匹配错误,我想知道是否有人可以查看并查看我的代码中的任何缺陷。
继承我的语法文件:
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<>();
}
}
如果有人在我的代码或语法文件中发现任何缺陷,请指出。感谢。
编辑:添加了访问者类。
答案 0 :(得分:1)
您正在调用parser.program()
两次(main
方法的第三行和第八行)。由于第一次调用会消耗所有输入(并且您不会在其间重置输入流),因此解析器的第二次运行将在文件末尾开始并失败。这就是为什么它在第8行期望begin
。
删除第二个电话,它会正常工作。