我想解析类似" a = 1; b = 2; {c = 3; d = 4;} e = 5; f = 6;"。我的问题是如何处理' {}'字符。 如果ignoreBlock为真,则应解析块内的值(但不会传播到r1的属性)。
using namespace boost::spirit;
using namespace std;
bool ignoreBlock = true;
qi::rule<std::string::iterator, vector<pair<string, int>>()> r1;
qi::rule<std::string::iterator, pair<string, int>()> r2;
qi::rule<std::string::iterator, vector<pair<string, int>>()> r3;
r1 = *(r2 | (qi::eps(phoenix::ref(ignoreBlock)==true) >> qi::omit[r3]) | r3);
r2 = qi::as<string>()[+qi::alnum] >> '=' >> qi::int_ >> ';';
r3 = '{' >> *r2 >> '}';
string s = { "a=1;b=2;{c=3;d=4;}e=5;f=6;"};
vector<pair<string, int>> v;
phrase_parse(s.begin(), s.end(), r1, boost::spirit::ascii::space, v);
此代码会导致一些错误,例如:
'static_cast': cannot convert from const std::vector<std::pair<std::string,int>,std::allocator<_Ty>>' to 'std::pair<std::string,int>'
如何正确处理这些条件部分?
答案 0 :(得分:0)
为什么在解析过程中没有任何改变时,会在规则中绑定ignoreBlock
?
qi::rule<std::string::iterator, vector<pair<string, int>>()> r1;
qi::rule<std::string::iterator, pair<string, int>()> r2;
r2 = qi::as<string>()[+qi::alnum] >> '=' >> qi::int_ >> ';';
if (ignoreBlock)
{
qi::rule<std::string::iterator, void()> r3;
r1 = *(r2 | r3);
r3 = '{' >> *r2 >> '}';
}
else
{
r1 = *(r2 | qi::lit('{') | qi::lit('}'));
}
这不会拒绝不平衡的括号,但可以适应。