使用Java遍历Antlr树

我对Antlr有疑问,我正在用它构建一个简单的解析器,但无法遍历树.我发现了许多在线教程,它们使用了getAst();. Parser类的功能.有人对这个有经验么?我感觉这样做的方式因版本而异.

grammar SimpleCalc;

options 
{
    output=AST; 
} 

tokens {
    PLUS    = '+' ;
    MINUS   = '-' ;
    MULT    = '*' ;
    DIV = '/' ;
    SEMICOLON = ';';
    EQUAL = '=';
    COMMA = ',';
    BRACKETL = '(';
    BRACKETR = ')';
}

任何人都对如何以另一种方式遍历树有任何想法或建议吗?

解决方法:

getAST()是CommonAST中的一种方法,用于ANTLRv2.x.

ANTLR v3.x改用CommonTree.当定义output = AST时,所有解析器规则都返回一个实例RuleReturnScope,该实例具有getTree()方法,您可以使用get树.

另请参阅此先前的问答,该问答显示了解析某些输入后如何获取AST:How to output the AST built using ANTLR?

上一篇:Linux5.9下DHCP服务器的配搭建


下一篇:C#-用于计数班级人数的部分语法