繁体   English   中英

Antlr4跳过规则而没有错误

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM