我有一个 antlr 词法分析器规则的奇怪副作用,我创建了一个(几乎)最小的工作示例来演示它。例如,在这个例子中,我想匹配字符串[0..1]
。但是当我调试语法时,到达解析器的令牌流只包含[..1]
. 第一个整数,无论它包含多少个数字,总是被消耗掉,我不知道这是怎么发生的。如果我删除FLOAT
规则一切都很好,所以我猜错误在于该规则的某个地方。但由于它根本不应该匹配任何东西,[0..1]
我很困惑。
对于我可能出错的任何指示,我都会很高兴。这是我的例子:
grammar min;
options{
language = Java;
output = AST;
ASTLabelType=CommonTree;
backtrack = true;
}
tokens {
DECLARATION;
}
declaration : LBRACEVAR a=INTEGER DDOTS b=INTEGER RBRACEVAR -> ^(DECLARATION $a $b);
EXP : 'e' | 'E';
LBRACEVAR: '[';
RBRACEVAR: ']';
DOT: '.';
DDOTS: '..';
FLOAT
: INTEGER DOT POS_INTEGER
| INTEGER DOT POS_INTEGER EXP INTEGER
| INTEGER EXP INTEGER
;
INTEGER : POS_INTEGER | NEG_INTEGER;
fragment NEG_INTEGER : ('-') POS_INTEGER;
fragment POS_INTEGER : NUMBER+;
fragment NUMBER: ('0'..'9');