我尝试修改 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)])
)
;