为什么我的语法规则会导致错误,只是因为我更改了规则名称的大小写?



我从这里复制antlr4 json语法:grammar json

我修改了一些规则和代码,如下所示:

grammar PyJson;
my_rule
: STRING
;
waha
: STRING
| INT
;
STRING
: '"' (ESC | SAFECODEPOINT)* '"'
;
fragment ESC
: '\' (["\/bfnrt] | UNICODE)
;
fragment UNICODE
: 'u' HEX HEX HEX HEX
;
fragment HEX
: [0-9a-fA-F]
;
fragment SAFECODEPOINT
: ~ ["\u0000-u001F]
;
fragment INT
: '0' | [1-9] [0-9]*
;
WS
: [ tnr] + -> skip
;

我使用my_rule来测试"helloWorld",它运行良好。但是,如果将规则"waha"更改为"WAHA",则会引发错误。

[@0,0:11='"helloWorld"',<WAHA>,1:0]
[@1,20:19='<EOF>',<EOF>,5:0]
line 1:0 mismatched input '"helloWorld"' expecting STRING

为什么语法规则运行错误只是因为我更改了规则的大小写? 你能帮我吗?谢谢!

以大写字母开头的规则名称会自动被视为词法分析器规则,否则它们是解析器规则。通过更改,您将waha转换为具有自己的令牌类型 (<WAHA>( 的词法分析器规则。这不是my_rule期望的STRING类型,因此语法错误。

最新更新