对于字母数字的单词,我有一个如下的词素。
属性 = 词位[+(boost::spirit::qi::alpha|boost::spirit::qi::digit)];
我想要一个语法规则,它会跳过不适合该规则的任何其他字符,并将这些字符放入向量中。
例如:输入:STR1 + STR2 % STR3 () STR4 = STR5+ STR6
output: (STR1, STR2, STR3, STR4, STR6)
我尝试过以下语法,但在解析字符串中的第一个单词后它会跳过所有内容。我怎样才能改变它来解析我所描述的?
typedef std::vector<std::wstring> Attributes;
template <typename It, typename Skipper=boost::spirit::qi::space_type>
struct AttributeParser : boost::spirit::qi::grammar<It, Attributes(), Skipper>
{
AttributeParser() : AttributeParser::base_type(expression)
{
expression =
*( attributes [phx::push_back(qi::_val, qi::_1)])
>> qi::omit[*qi:char_]
;
attributes = qi::lexeme[+(boost::spirit::qi::alpha|qi::boost::spirit::qi::digit)];
BOOST_SPIRIT_DEBUG_NODE(expression);
BOOST_SPIRIT_DEBUG_NODE(attributes);
}
private:
boost::spirit::qi::rule<It, std::wstring() , Skipper> attributes;
boost::spirit::qi::rule<It, Attributes() , Skipper> expression;
};