我有以下语法:
rule: 'aaa' | 'a' 'a';
它可以成功解析字符串'aaa',但无法解析'aa'并出现以下错误:
line 1:2 mismatched character '<EOF>' expecting 'a'
仅供参考,这是词法分析器的问题而不是解析器的问题,因为我什至不调用解析器。主要功能如下所示:
@members {
public static void main(String[] args) throws Exception {
RecipeLexer lexer = new RecipeLexer(new ANTLRInputStream(System.in));
for (Token t = lexer.nextToken(); t.getType() != EOF; t = lexer.nextToken())
System.out.println(t.getType());
}
}
结果与更明显的版本相同:
rule: AAA | A A;
AAA: 'aaa';
A: 'a';
显然,ANTLR 词法分析器尝试将输入“aa”与失败的规则 AAA 匹配。除了 ANTLR 是一个 LL(*) 解析器或其他什么之外,词法分析器应该与解析器分开工作,它应该能够解决歧义。该语法适用于良好的旧lex(或flex),但它似乎不适用于 ANTLR。那么这里的问题是什么?
谢谢您的帮助!