Antlr编译文本,但在有空格时总是抛出错误

时间:2016-12-14 18:08:43

标签: antlr

所以这是我的语法:

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: ' '

除此之外一切正常但如果我能摆脱这些消息仍然会很好。

1 个答案:

答案 0 :(得分:3)

你只是将标签和换行符放在隐藏的通道上,而不是空格。

而不是:

WS: [\t\r\n]+ -> channel(HIDDEN);

做的:

WS: [ \t\r\n]+ -> channel(HIDDEN);