2

我在从解析器语法转移到树语法时遇到问题,当我使用树运算符(^,!)而不是重写规则(->)时,问题就出现了

where_clause
    :   'where'! condition_or
    ;

condition_or
    :   condition_and ( 'or'^ condition_and )*
    ;

condition_and
    :   condition_expr ( 'and'^ condition_expr )*
    ;

condition_expr
    :   condition_comparision
//  |   condition_in
//  |   condition_like
    ;

condition_comparision
    :   column_identifier ('=' | '!=' | '>' | '<')^ sql_element
    ;

对于上面的解析器语法,树语法会是什么样子?由于这不是递归的,我无法将其折叠成树语法中的单个规则。

使用重写语法强制重写解析器语法的另一种替代方法

condition_or
    :   condition_and -> condition_and 
     ( 'or' x=condition_and -> ^('or' condition_or $x))*
    ;

有没有更简单的方法来做到这一点?

谢谢

4

1 回答 1

2

相应的树语法如下所示:

where_clause
    :   condition_or
    ;

condition_or
    :   ^('or' condition_and condition_and)
    ;

condition_and
    :   ^('and' condition_expr condition_expr)
    ;

condition_expr
    :   condition_comparision
    ;

condition_comparision
    :   ^('=' column_identifier sql_element)
    |   ^('!=' column_identifier sql_element)
    |   ^('>' column_identifier sql_element)
    |   ^('<' column_identifier sql_element)
    ;
于 2012-05-01T06:37:26.350 回答