这正是 Spirit 符号表的用途——事实上,它是 Spirit 文档(Spirit.X3:罗马数字)中的主要教程之一。
首先,您需要适当地调整您的类型:
struct person {
std::string name;
gender_t gender;
std::vector<std::string> friends;
};
BOOST_FUSION_ADAPT_STRUCT(person, name, gender, friends)
注意我已经改变了成员的顺序——因为我们想要解析名字 -> 性别 -> 朋友,如果我们也以这种方式构造我们的类型是最简单的。现在,解析:
person parse_person(std::string const& str) {
namespace x3 = boost::spirit::x3;
struct gender_table : x3::symbols<gender_t> {
gender_table() {
add ("male" , gender_t::male)
("female" , gender_t::female);
}
} const gender;
auto const word = x3::lexeme[+~x3::space];
auto const parser
= word // name
>> (gender | x3::attr(gender_t::female)) // gender
>> *word; // friends
person ret{};
x3::phrase_parse(str.cbegin(), str.cend(), parser, x3::space, ret);
return ret;
}
Online Demo
(如果您不想更改数据成员的顺序以方便解析,那么这里有一种方法可以使所有这些都成为非侵入性的。)