Я хотел бы проанализировать два типа выражения с логическим значением:
- первое было бы выражением инициализации с логическим значением, например: init : false
- и последнее было бы производным выражением с логическим значением, например: derive : !express or (express and (amount >= 100))
Моя идея состоит в том, чтобы поместить семантические предикаты в набор правил. Цель состоит в том, чтобы, когда я анализирую логическое выражение, начинающееся со слова «init», оно должно перейти только к одному предложенному альтернативному правилу, которое boolliteral strong>, последняя альтернатива в boolExpression. И если это выражение, начинающееся со слова "вывести", то оно может иметь доступ ко всем альтернативам boolExpression.
Я знаю, что могу создать два типа boolExpression без семантических предикатов, таких как boolExpressionInit и boolExpressionDerive... Но я хотел бы попробовать со своей идеей, может ли она работать только с одним boolExpression с семантическими предикатами.
Вот моя грамматика
grammar TestExpression;
@header
{
package testexpressionparser;
}
@parser::members {
int vConstraintType;
}
/* SYNTAX RULES */
textInput : initDefinition
| derDefinition ;
initDefinition : t=INIT {vConstraintType = $t.type;} ':' boolExpression ;
derDefinition : t=DERIVE {vConstraintType = $t.type;} ':' boolExpression ;
boolExpression : {vConstraintType != INIT || vConstraintType == DERIVE}? boolExpression (boolOp|relOp) boolExpression
| {vConstraintType != INIT || vConstraintType == DERIVE}? NOT boolExpression
| {vConstraintType != INIT || vConstraintType == DERIVE}? '(' boolExpression ')'
| {vConstraintType != INIT || vConstraintType == DERIVE}? attributeName
| {vConstraintType != INIT || vConstraintType == DERIVE}? numliteral
| {vConstraintType == INIT || vConstraintType == DERIVE}? boolliteral
;
boolOp : OR | AND ;
relOp : EQ | NEQ | GT | LT | GEQT | LEQT ;
attributeName : WORD;
numliteral : intliteral | decliteral;
intliteral : INT ;
decliteral : DEC ;
boolliteral : BOOLEAN;
/* LEXICAL RULES */
INIT : 'init';
DERIVE : 'derive';
BOOLEAN : 'true' | 'false' ;
BRACKETSTART : '(' ;
BRACKETSTOP : ')' ;
BRACESTART : '{' ;
BRACESTOP : '}' ;
EQ : '=' ;
NEQ : '!=' ;
NOT : '!' ;
GT : '>' ;
LT : '<' ;
GEQT : '>=' ;
LEQT : '<=' ;
OR : 'or' ;
AND : 'and' ;
DEC : [0-9]* '.' [0-9]* ;
INT : ZERO | POSITIF;
ZERO : '0';
POSITIF : [1-9] [0-9]* ;
WORD : [a-zA-Z] [_0-9a-zA-Z]* ;
WS : (SPACE | NEWLINE)+ -> skip ;
SPACE : [ \t] ; /* Space or tab */
NEWLINE : '\r'? '\n' ; /* Carriage return and new line */
Я за исключением того, что грамматика будет работать успешно, но я получаю следующее: "ошибка (119): TestExpression.g4::: Следующие наборы правил являются взаимно леворекурсивными [boolExpression]
1 ошибка (ошибки) BUILD FAIL "
vConstraintType
меняет свое значение? Также опубликуйте минимально воспроизводимый пример. - person sepp2k   schedule 29.05.2019