我需要解析包含键/值对和键/子表达式对的 1 行表达式,例如:
123=a 456=b 789=(a b c) 111=((1=a 2=b 3=c) (1=x 2=y 3=z) (123=(x y z))) 666=evil
为了使解析器更简单,我愿意分几个步骤进行解析,将第一级标签(这里是 123、456、789、111 和 666)分开,然后在另一个步骤中解析它们的内容。这里 789 的值是"a b c"
, 111 的值为(1=a 2=b 3=c) (1=x 2=y 3=z) (123=(x y z))
.
但是语法在这一点上打败了我,所以我可以找到一种方法来获取匹配括号之间的表达式。我得到的 111 是(1=a 2=b 3=c
,它以第一个右括号结束。
我找到了这个方便的示例并尝试使用它,但没有成功:
#include <map>
#include <string>
#include <boost/spirit/include/classic.hpp>
#include <boost/spirit/include/qi.hpp>
#include <boost/fusion/include/std_pair.hpp>
namespace qi = boost::spirit::qi;
void main()
{
auto value = +qi::char_("a-zA-Z_0-9");
auto key = qi::char_("a-zA-Z_") >> *qi::char_("a-zA-Z_0-9");
qi::rule<std::string::iterator, std::pair<std::string, std::string>()> pair = key >> -('=' >> value);
qi::rule<std::string::iterator, std::map<std::string, std::string>()> query = pair >> *((qi::lit(';') | '&') >> pair);
std::string input("key1=value1;key2;key3=value3"); // input to parse
std::string::iterator begin = input.begin();
std::string::iterator end = input.end();
std::map<std::string, std::string> m; // map to receive results
bool result = qi::parse(begin, end, query, m); // returns true if successful
}
我怎么能做到这一点?
编辑:我在http://boost-spirit.com/home/articles/qi-example/parsing-a-list-of-key-value-pairs-using-spirit-qi/找到了这个例子