[英]N-ary operators in ANTLR4 grammar
我有一個解析 boolean 公式的語法:
expr: op=NOT right=expr #Not
| left=expr op=AND right=expr #And
| left=expr op=OR right=expr #Or
| left=expr op=XOR right=expr #Xor
| <assoc=right> left=expr op=IMPL right=expr #Implication
| <assoc=right> left=expr op=EQ right=expr #Equivalence
| boolean=BOOL #Boolean
| '(' content=expr+ ')' #Brackets
| atomic=ATOMIC #Atomic
;
BOOL : TRUE|FALSE;
NOT : ('!'|'not');
AND : ('&'|'and');
OR : ('|'|'or');
XOR : ('^'|'xor');
IMPL : '->';
EQ : '<->';
TRUE : ('True'|'true');
FALSE : ('False'|'false');
ATOMIC : [a-z]+([_]?[a-z]+)*;
WS : [ \t\n]+ -> skip; //Skip whitespaces
如何將AND
、 OR
和XOR
更改為 n 元而不是二進制(以便這些運算符的子級處於同一級別)? 我嘗試用expr (op=AND expr)+
替換left=expr op=AND right=expr
,這不會改變任何東西。
這樣的事情可以解決問題:
expr
: <assoc=right> expr IMPL expr
| <assoc=right> expr EQ expr
| xor_expr
;
xor_expr
: or_expr (XOR or_expr)*
;
or_expr
: and_expr (OR and_expr)*
;
and_expr
: unary (AND unary)*
;
unary
: NOT atom
| atom
;
atom
: BOOL
| '(' expr+ ')'
| ATOMIC
;
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.