消除XText中的左递归

时间:2014-02-23 21:34:17

标签: recursion xtext left-recursion

这是NuSMV语言语法的一部分:

BasicExpression:
Constant | '(' BasicExpression ')' | '!' BasicExpression | BasicExpression '&' BasicExpression;
Constant:
BooleanConstant
BooleanConstant: 
'TRUE' | 'FALSE';

不幸的是,XText抛出了一个异常,表明该语法中存在左递归。 我该如何解决?

感谢。

2 个答案:

答案 0 :(得分:1)

您可以简单地引入一条新规则(新层):

BasicExpression:
    firstContent=ExpressionContent ("&" secondContent=ExpressionContent)?
;

ExpressionContent:
    Constant 
    | '(' BasicExpression ')' 
    | '!' BasicExpression 
;

这样,规则不再是递归的。

问候Krzmbrzl

答案 1 :(得分:0)

查看this articleofficial documentation,它将详细解释如何处理语言递归,并考虑运算符优先级。