所以这是我的语法:
grammar Test;
prog: stmt_list;
stmt_list
: stmt_list stmt ';'
| stmt ';'
;
stmt
: assignment
| bind
;
assignment: 'var' IDENTIFIER ('=' | '+=' | '-=' | '*=' | '/=') expression;
type
: IDENTIFIER
| primitiveType
;
primitiveType
: 'int'
| 'float'
| 'string'
| 'bool'
;
expression
: atom
| expression ('*' | '/') expression
| expression ('+' | '-') expression
;
atom
: '(' expression ')'
| IDENTIFIER
| INT
| STRING
;
IDENTIFIER: [A-z_][A-z_0-9]*;
INT: [1-9][0-9]*;
STRING: '"' [A-z] '"';
WS: [\t\r\n]+ -> channel(HIDDEN);
我可以用antlr编译它,一切正常。当我用grun进行测试时,它会编译,但它会引发一个"令牌识别错误"只要有空白。例如,使用此输入:
var a = b + c;
我明白了:
line 1:3 token recognition error at: ' '
line 1:5 token recognition error at: ' '
line 1:7 token recognition error at: ' '
line 1:9 token recognition error at: ' '
line 1:11 token recognition error at: ' '
除此之外一切正常但如果我能摆脱这些消息仍然会很好。
答案 0 :(得分:3)
你只是将标签和换行符放在隐藏的通道上,而不是空格。
而不是:
WS: [\t\r\n]+ -> channel(HIDDEN);
做的:
WS: [ \t\r\n]+ -> channel(HIDDEN);