我有以下语法:
grammar Expr;
expr : '-' expr # unaryOpExpr
| expr ('*'|'/'|'%') expr # mulDivModuloExpr
| expr ('+'|'-') expr # addSubExpr
| '(' expr ')' # nestedExpr
| IDENTIFIER '(' fnArgs? ')' # functionExpr
| IDENTIFIER # identifierExpr
| DOUBLE # doubleExpr
| LONG # longExpr
| STRING # string
;
fnArgs : expr (',' expr)* # functionArgs
;
IDENTIFIER : [_$a-zA-Z][_$a-zA-Z0-9]* | '"' (ESC | ~ ["\\])* '"';
LONG : [0-9]+;
DOUBLE : [0-9]+ '.' [0-9]*;
WS : [ \t\r\n]+ -> skip ;
STRING: '"' (~["\\\r\n] | ESC)* '"';
fragment ESC : '\\' (['"\\/bfnrt] | UNICODE) ;
fragment UNICODE : 'u' HEX HEX HEX HEX ;
fragment HEX : [0-9a-fA-F] ;
MINUS : '-' ;
MUL : '*' ;
DIV : '/' ;
MODULO : '%' ;
PLUS : '+' ;
// math function
MAX: 'MAX';
当我输入以下文字时,它应该有效
-1.1
输入以下文本时出现错误:
-1.1ffff
我认为它应该报告一个错误,错误antlr并没有这样做,antlr捕获了先前的“ -1.1”,放弃了“ ffff”,但是我想更改此行为,没有放弃无效的令牌,而是抛出异常,报告检测到无效令牌。
那我该怎么办,谢谢你的建议
您是否使用expr作为主要规则?如果是这样,请制定另一个规则,将其命名为“解析”或“程序”,然后像这样简单地编写它:
parse: expr EOF;
这将使antlr不会忽略没有意义的尾随标记,而实际上会引发错误。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句