[英]Antlr4 skipping a rule without error
我有一个非常简单的语法。 在以下语法中, antlr4似乎正在跳过toLabel
规则。
grammar SOSLGrammar;
options {
language = Java;
}
main : query;
query : findClause
toLabelClause?
searchGroupClause?
;
findClause : find '{' searchClause '}';
find : Find;
searchClause : '(' searchClause ')' #bracketedSearch
| searchClause AND NOT searchClause #notSearch
| searchClause AND searchClause #andSearch
| searchClause OR searchClause #orSearch
|terms #simple
;
terms : term+;
term : StringLiteral|('"' reservedWordsWithOperators '"') | (TermLiteral|reservedWords);
toLabelClause : ToLabel '(' ')';
searchGroupClause : IN (email|all|phone|sidebar|name) Fields;
name : Name;
email : Email;
all : All;
phone : Phone;
sidebar : Sidebar;
reservedWordsWithOperators : reservedWords | NOT | AND | OR |IN;
reservedWords : Find|ToLabel|Name|Email|All|Phone|Sidebar;
Find : F I N D;
ToLabel : T O L A B E L;
Fields : F I E L D S;
Name : N A M E;
All : A L L;
Phone : P H O N E;
Sidebar : S I D E B A R;
Email : E M A I L;
AND : A N D;
OR : O R;
NOT : N O T;
IN : I N;
StringLiteral : '"' ( ~('\\'|'"') )* '"';
TermLiteral : ~('\\'|'"' | ' ' | '\t' | '}' | '{' | '\r' | '\n')+;
WS : (' ' | '\r' | '\n' | '\t' | '\f' | '\b' | '\r\n' )+ -> skip;
fragment A : 'A' | 'a' ;
fragment B : 'B' | 'b' ;
fragment C : 'C' | 'c' ;
fragment D : 'D' | 'd' ;
fragment E : 'E' | 'e' ;
fragment F : 'F' | 'f' ;
fragment G : 'G' | 'g' ;
fragment H : 'H' | 'h' ;
fragment I : 'I' | 'i' ;
fragment J : 'J' | 'j' ;
fragment K : 'K' | 'k' ;
fragment L : 'L' | 'l' ;
fragment M : 'M' | 'm' ;
fragment N : 'N' | 'n' ;
fragment O : 'O' | 'o' ;
fragment P : 'P' | 'p' ;
fragment Q : 'Q' | 'q' ;
fragment R : 'R' | 'r' ;
fragment S : 'S' | 's' ;
fragment T : 'T' | 't' ;
fragment U : 'U' | 'u' ;
fragment V : 'V' | 'v' ;
fragment W : 'W' | 'w' ;
fragment X : 'X' | 'x' ;
fragment Y : 'Y' | 'y' ;
fragment Z : 'Z' | 'z' ;
我运行了以下测试:
java org.antlr.v4.runtime.misc.TestRig SOSLGrammar main -gui -trace
与以下行
找到{abc} toLabel()
我希望生成的树显示toLabel()
但它似乎被默默地忽略了。
这种语法可能有什么问题?
谢谢
拉胡尔〜
您期望toLabel()
的输入产生3个令牌:
toLabel
(
)
实际上,由于TermLiteral
规则允许显示(
和)
字符,因此正在生成单个TermLiteral
令牌toLabel()
。 之所以选择该令牌,是因为ToLabel
令牌更长。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.