java - 如何访问 ANTLR 词法分析器令牌
问题描述
我已经指定了以下 ANTLR 语法:
expression: ...
| extractor=EXTRACTOR '(' setElementDefinition ',' expression ')' #setExtractorExp
| ... ;
EXTRACTOR: 'select'
| 'choose' ;
我想知道在解析这个表达式时我正在处理哪种类型的提取。一种方法是将提取器字段与包含提取器类型的字符串进行比较,如下所示:
@Override
public Expression visitSetExtractorExp(MyParser.SetExtractorExpContext ctx) {
if(ctx.extractor.getText().equals("select")) { ... }
}
但是我不喜欢在这里重复提取器的名称,以防我以后选择更改提取器的名称。那么有没有办法访问词法分析器令牌?
我在想象类似的东西if(ctx.extractor == MyLexer.EXTRACTOR.choose)
。
解决方案
现在,你EXTRACTOR
只有一种类型,制作"select"
和"choose"
几乎相同。区分的唯一方法是像您已经在做的那样进行字符串比较。如果您不希望这样,请执行以下操作:
expression
: ...
| extractor '(' setElementDefinition ',' expression ')' #setExtractorExp
| ...
;
extractor
: SELECT
| CHOOSE
;
SELECT : 'select';
CHOOSE : 'choose';
在您的访客中:
@Override
public Expression visitSetExtractorExp(MyParser.SetExtractorExpContext ctx) {
if(ctx.extractor().start.getType() == MyLexer.SELECT) { ... }
else if(ctx.extractor().start.getType() == MyLexer.CHOOSE) { ... }
}
这样您就不必复制(魔术)字符串。
推荐阅读
- python - 当我将 writerow 与 CSV 文件一起使用时删除一个空行
- maven - Maven - 如何创建一个将文件放在根目录中的 POM
- google-analytics - 谷歌分析 - 自定义维度发送到错误网站的谷歌分析
- python - 如何制作正确的设置文件?
- python - Python lib NetworkX:未充分利用 CPU
- python - 我在使用旨在根据列类别拆分 Excel 的 Python 脚本时遇到错误
- python - 尝试在不使用“in”运算符的情况下为代码执行 python 并且它不起作用
- protocol-buffers - 如何使用 grpcurl 使用客户端流式 gRPC 分块上传图像
- javascript - 在传递(作为其参数)绑定方法本身使用的动态值的函数内使用绑定
- java - 在 macOS Big Sur 上将 maven 添加到 PATH