我正在尝试匹配一个非常基本的ANTLR语法。但是ANTLR一直告诉我他得到了输入'。'期待'。'
完整错误是:
line 1:0 extraneous input '.' expecting '.'
line 1:2 missing '*' at '<EOF>'
用语法:
grammar regex;
@parser::header
{
package antlr;
}
@lexer::header
{
package antlr;
}
WHITESPACE : (' ' | '\t' | '\n' | '\r') -> channel(HIDDEN);
COMP : '.';
KLEENE : '*';
start : COMP KLEENE;
并输入:
.*
两个文件都有相同的字符集:
regex.g: text/plain; charset=us-ascii
test.grammar: text/plain; charset=us-ascii
应该没有Lexer规则混淆。为什么这不能按预期工作?
答案 0 :(得分:1)
给出你的示例语法和这个测试类:
import org.antlr.v4.runtime.*;
public class Main {
public static void main(String[] args) {
String source = ".*";
regexLexer lexer = new regexLexer(CharStreams.fromString(source));
regexParser parser = new regexParser(new CommonTokenStream(lexer));
System.out.println(parser.start().toStringTree(parser));
}
}
以下内容将打印到我的控制台:
(start . *)
我的猜测是你要么将语法笨了太多而导致原语法中的错误消失,或者你没有生成新的词法分析器/解析器类。