解析时的antlr4语法错误

时间:2014-10-06 15:56:41

标签: antlr grammar antlr4

我有以下语法:

grammar Token;

prog: (expr NL?)+ EOF;

expr: '[' type ']';

type : typeid ':' value;

typeid : 'TXT' | 'ENC' | 'USR';

value: Text | INT;

INT :   '0' | [1-9] [0-9]*;

//WS : [ \t]+;
WS  :   [ \t\n\r]+ -> skip ;
NL:  '\r'? '\n';
Text : ~[\]\[\n\r"]+ ;

我需要解析的文字如下所示

[TXT:look at me!]
[USR:19700]
[TXT:, can I go there?]
[ENC:124124]
[TXT:this is needed for you to go...]

我需要拆分此文本,但在运行grun.bat Token prog -gui -trace -diagnostics

时出现了一些错误
enter   prog, LT(1)=[
enter   expr, LT(1)=[
consume [@0,0:0='[',<3>,1:0] rule expr
enter   type, LT(1)=TXT:look at me!
enter   typeid, LT(1)=TXT:look at me!
line 1:1 mismatched input 'TXT:look at me!' expecting {'TXT', 'ENC', 'USR'}
... much more ...

enter image description here

我的语法出了什么问题?拜托,帮助我!

1 个答案:

答案 0 :(得分:1)

您必须明白,令牌不是根据解析器尝试匹配的内容创建的。词法分析器尝试匹配尽可能多的字符(独立于该解析器!):您的Text标记应该以不同方式定义。

您可以让Text规则成为解析器规则,并匹配单个字符标记,如下所示:

grammar Token;

prog   : expr+ EOF;
expr   : '[' type ']';
type   : typeid ':' value;
typeid : 'TXT' | 'ENC' | 'USR';
value  : text | INT;
text   : CHAR+;

INT  : '0' | [1-9] [0-9]*;
WS   : [ \t\n\r]+ -> skip ;
CHAR : ~[\[\]\r\n];
相关问题