当我运行以下语法时:
test : WORD+;
WORD : ('a'..'z')+;
WS : ' '+ {$channel = HIDDEN;};
我给输入“?test”为什么antlr接受这个作为有效输入?我认为 ('a'..'z') 只会匹配小写字母中的字符?
使用您发布的语法解析输入字符串时, ANTLR确实会产生错误。?test
通常情况下,错误在于围绕 ANTLR 使用的工具(不幸的是,我看到 ANTLRWorks 也经常发生这种情况!)。
要自己测试(正确),请创建一个文件Test.g
:
grammar Test;
test : WORD+;
WORD : ('a'..'z')+;
WS : ' '+ {$channel = HIDDEN;};
和一个文件Main.java
:
import org.antlr.runtime.*;
public class Main {
public static void main(String[] args) throws Exception {
ANTLRStringStream in = new ANTLRStringStream("?test");
TestLexer lexer = new TestLexer(in);
CommonTokenStream tokens = new CommonTokenStream(lexer);
TestParser parser = new TestParser(tokens);
parser.test();
}
}
并在同一目录中下载ANTLR 3.2 JAR的副本。
现在生成一个词法分析器和解析器:
java -cp antlr-3.2.jar org.antlr.Tool Test.g
编译所有 Java 源文件:
javac -cp antlr-3.2.jar *.java
并运行 Main 类:
java -cp .:antlr-3.2.jar Main
(如果您在 Windows 上:
,请替换为!);
这将产生以下错误消息:
line 1:0 no viable alternative at character '?'