トークンを持っています OR:'OR'; ブール式 (a==b OR a==c) を評価するために使用する文字リスト AZ、AK、OR、GA にある州の略語を解析するための別のルールがあります... 私が見つけているのは、その antlr です状態リストにエラーがあり、OR はor
トークンではなくトークンであるべきだと考えています
stateName
: CHAR CHAR (','|EOF) ->^(STATE CHAR+)
;
このあいまいさを解決するにはどうすればよいでしょうか。
ここに私が解析しようとしているルールのいくつかがあります
- THEN STATE_LICENSE AL、AK、AS、AZ、AR、CT、DE、DC、FM、FL、GA、GU、HI、ID、IL、IN、IA、KS、KY、LA、ME、MH、MD、MA、 MI,MN,MS,MO,MT,NE,NV,NH,NJ,NM,NY,NC,ND,MP,OH,OK,OR,PW,PA
- IF 1198 == "x" OR 1190 != "x" THEN 800 を無効にする
- IF 801 >= "1000000" THEN DISPLAY_ERROR "それは+高すぎます.+Go+and+get+cheaper+one+!!!"
これが私が使用している文法です
grammar PointFieldRule;
options
{
//language = 'CSharp3';
output=AST;
ASTLabelType=CommonTree;
}
tokens{
STATE;
}
rule : ifExpression? actionExpression EOF!
;
ifExpression
:'IF'! logicalConditionExpression
;
logicalConditionExpression
: booleanAndConditionExpression ( BigOR^ booleanAndConditionExpression)*
;
booleanAndConditionExpression
: logicalCondition ( BigAND^ logicalCondition )*
;
BigAND : 'and'|'AND';
logicalCondition
: booleanAndCondition ( OR^ booleanAndCondition )*
;
OR:'||';
booleanAndCondition
: evalCondition ( AND^ evalCondition)*
;
AND: '&&';
evalCondition
: FieldID OPERATOR^ (FieldID|STRING)
;
actionExpression
: 'THEN'! (actionMessage | fieldAction | stateAction )
;
actionMessage
: ('DISPLAY_WARNING' | 'DISPLAY_ERROR')^ STRING
;
fieldAction
: ('DISABLE' | 'REQUIRED')^ FieldID ( ','! FieldID )*
;
stateAction
: 'STATE_LICENSE'^ stateName+ //(','! stateName)*
;
FieldID
:'0'..'9'+;
/* item : FIELD
| CHAR CHAR
;
*/
//class csharpTestLexer extends Lexer;
stateName
: CHAR CHAR (','|EOF) ->^(STATE CHAR+)
;
CHAR: ('a'..'z'|'A'..'Z')
;
WS : (' '
| '\t'
| '\n'
| '\r')
{ $channel = HIDDEN; }
//{ $channel = Hidden; }
;
OPERATOR
: '=='
| '!='
| '<='
| '>='
| '<'
| '>'
| 'TD'
| 'FD'
| 'PD'
| 'TY'
| 'LY'
| 'TM'
| 'LM'
| '+(DELTA%)>'
| '-(DELTA%)>'
| '+(DELTA)>'
| '-(DELTA)>'
| 'LIKE'
;
STRING
: '"' ( ESC_SEQ | ~('\\'|'"') )* '"'
;
fragment
HEX_DIGIT : ('0'..'9'|'a'..'f'|'A'..'F') ;
fragment
ESC_SEQ
: '\\' ('b'|'t'|'n'|'f'|'r'|'\"'|'\''|'\\')
| UNICODE_ESC
| OCTAL_ESC
;
fragment
OCTAL_ESC
: '\\' ('0'..'3') ('0'..'7') ('0'..'7')
| '\\' ('0'..'7') ('0'..'7')
| '\\' ('0'..'7')
;
fragment
UNICODE_ESC
: '\\' 'u' HEX_DIGIT HEX_DIGIT HEX_DIGIT HEX_DIGIT
;
//fragment
BigOR: 'or'|'OR';