2017-08-11 236 views
6

我正在使用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。

回答

2

假设你正在使用的语法here,你要解析Java文件的出发点是

ParseTree tree = parser.compilationUnit(); 

(对于任何不使用的语法,任何你想要的,你命名你的顶级解析器规则)。

1

你不是应该做的:

ParseTree tree = parser.input(); 

如计算器的例子吗?

+0

'ParseTree tree = parser.compilationUnit();'将是解析Java文件的起点。 (假设Java语法[这里](https://github.com/antlr/grammars-v4/blob/master/java/Java.g4)) –

+0

@BilltheLizard thanks.make答案,所以我可以+1它 –

+0

@BilltheLizard没错。请张贴这个答案。谢谢。 – ConductedClever