0

我尝试修改 boost::spirit 的 mini_c 示例以匹配我现有的词汇表。

因此,我添加了一个运算符“NOT”,它的行为应该等同于“!”:

unary_expr =
        primary_expr
    |   ("NOT" > primary_expr           [op(op_not)]) // This does not work
    |   ('!' > primary_expr             [op(op_not)])
    |   ('-' > primary_expr             [op(op_neg)])
    |   ('+' > primary_expr)
    ;

我可以编译修改后的源代码,但是当我尝试执行它时,它无法解析。我该如何解决这个问题?

编辑: 由于我想访问外部变量,我做了另一个修改,以便在编译时构建这些变量的列表:

identifier %=
    raw[lexeme[alpha >> *(alnum | '§' | '_' | '.' | '-' )]]
    ;
variable =
       identifier      [add_var(_1)]
    ;

其中 add_var 和 identifier 定义为

rule<Iterator, std::string(), white_space> identifier;
function<var_adder> add_var;

如果我不使用此修改,则可以使用“NOT”。通过修改,使用“NOT”会产生解析错误。

编辑2: 以下条件表达式确实有效:

logical_expr =
    relational_expr
    >> *(  ("AND" > relational_expr     [op(op_and)])
        |   ("OR" > relational_expr     [op(op_or)])
        )
    ;
4

1 回答 1

2

随着你的改变小测试:

int main()
{
    return NOT 1;
}

解析成功并返回0. 所以对我来说,什么对你不起作用并不明显。请您也提供一个失败的输入示例吗?

于 2010-08-28T20:03:06.210 回答