ANTLR v4,JavaLexer和JavaParser作为解析树返回null
问题描述:
我正在使用antlr v4为其他目的提取Java程序的分析树。我从这个样本开始:ANTLR v4 visitor sampleANTLR v4,JavaLexer和JavaParser作为解析树返回null
而且我已经测试给定链路上的步骤检查是否正常工作,一切都消失了右:
java Run
a = 1+2
b = a^2
c = a+b*(a-1)
a+b+c
^Z
Result: 33.0
然后我写我自己来解析Java程序的结构如下:
|_Java.g4
|_Java.tokens
|_JavaBaseVisitor.java
|_JavaLexer.java
|_JavaLexer.tokens
|_JavaParser.java
|_JavaTreeExtractorVisitor.java
|_JavaVisitor.java
|_Run.java
而且Run.java是如下:
import org.antlr.v4.runtime.*;
import org.antlr.v4.runtime.tree.*;
public class Run {
public static void main(String[] args) throws Exception {
CharStream input = CharStreams.fromFileName("F:\\Projects\\Java\\Netbeans\\ASTProj\\JavaTreeExtractor\\prog.java");
JavaLexer lexer = new JavaLexer(input);
CommonTokenStream tokens = new CommonTokenStream(lexer);
JavaParser parser = new JavaParser(tokens);
ParseTree tree = parser.getContext();
JavaTreeExtractorVisitor calcVisitor = new JavaTreeExtractorVisitor();
String result = calcVisitor.visit(tree);
System.out.println("Result: " + result);
}
}
但在语句ParseTree tree = parser.getContext();
上,树对象为空。 由于我是antlr的新手,有任何建议让我检查或解决?
(如果需要更多信息,只需通知我)。
TG。
答
假设你正在使用的语法here,你要解析Java文件的出发点是
ParseTree tree = parser.compilationUnit();
(对于任何不使用的语法,任何你想要的,你命名你的*解析器规则)。
答
你不是应该做的:
ParseTree tree = parser.input();
如计算器的例子吗?
'ParseTree tree = parser.compilationUnit();'将是解析Java文件的起点。 (假设Java语法[这里](https://github.com/antlr/grammars-v4/blob/master/java/Java.g4)) –
@BilltheLizard thanks.make答案,所以我可以+1它 –
@BilltheLizard没错。请张贴这个答案。谢谢。 – ConductedClever