我正在尝试使用Java.g4语法和Antlr4解析Java类文件。
有一个特殊的解析器规则,如下所示:
classOrInterfaceType
: Identifier typeArguments? ('.' Identifier typeArguments? )*
;
我以这种方式在访问者类中解析它:
public String visitClassOrInterfaceType(JavaParser.ClassOrInterfaceTypeContext ctx) {
StringBuilder clsIntr = new StringBuilder("");
int n = ctx.getChildCount();
for(int i = 0; i < n; i++){
TerminalNode id = ctx.Identifier(i);
if(id!=null){
clsIntr.append(id.getText()).append(" ");
}
TypeArgumentsContext typArgCtx =ctx.typeArguments(i);
if(typArgCtx!=null){
String val = this.visitTypeArguments(typArgCtx);
clsIntr.append(val);
}
}
return clsIntr.toString();
}
这是正确的还是有其他方法可以做到这一点?
最佳答案
您的方法看起来不错,即使这最终取决于您实际要执行的操作。我的水晶球告诉我,您尝试通过解析树来重建原始查询文本。但是,您可以轻松得多。每个解析上下文都有start和stop成员,这些成员持有此上下文代表的解析文本范围的标记。您可以使用它们直接获得与输入时完全相同的原始文本(通过令牌流和令牌的位置)。