我有一个考虑ANTLR4及其语法(产品)的问题。
注:我不会详细介绍我的例子,因为我的怀疑是技术性的。
我有以下作品:
prog
: stat '.'+
;
stat
: word+
;
word
: WORD1
| WORD2
;
WORD1 : some regular expression
WORD2 : some regular expression
WS : [ \t\r\n]+ -> skip;
因此,我的语法必须识别多个与'.‘分开的句子。每个句子都有一个或多个单词(WORD1或WORD2)。而且,正如您所看到的,当我在空格、制表符或新行中出现时,我必须跳过它们。所以我的问题是,这个语法只识别第一句话,并打印出我在stat生成完成时给出的一些单词。但它没有继续到其他句子。我不明白为什么,因为对于主要规则(Prog),我们有stat'.'+。如果有人能帮我清理这件事,我会很感激的。
发布于 2022-05-19 18:53:06
prog : stat '.'+;
的意思是:匹配一个stat
,后面跟着一个或多个'.'
。
prog : (stat '.')+;
解析器没有使用所有的标记(或者尝试这样做),这是因为您没有使用EOF
令牌“锚定”您的开始生产。试试这个:
prog : (stat '.')+ EOF;
这将迫使ANTLR使用所有令牌(或在无法使用所有令牌时产生错误)。
https://stackoverflow.com/questions/72309563
复制相似问题