一个简单的解析器Coliru。解析器-(+x3::alpha)
应该能够传播类型的属性boost::optional<std::string>
就像齐一样。但它无法编译。
std::string const input = "abc";
boost::optional<std::string> attr;
if(x3::parse(boost::begin(input),boost::end(input),
-(+x3::alpha),
attr)) {
std::cout<<"match!"<<std::endl;
}
else {
std::cout<<"NOT match!"<<std::endl;
}
我不认为“应该能够……像 Qi 那样”这一规范性主张没有道理。 X3 不是 Qi 的演变,有很好的理由(比如这个)。
一个经常重复出现的模式是,在更复杂的传播场景中需要类型提示。丑陋的冗长方式可能是这样的:
-(x3::rule<struct _, std::string> {} = +x3::alpha),
Live On Coliru
或者你可以使用黑客我之前描述过:
namespace {
template <typename T>
struct as_type {
template <typename Expr>
auto operator[](Expr&& expr) const {
return x3::rule<struct _, T>{"as"} = x3::as_parser(std::forward<Expr>(expr));
}
};
template <typename T> static const as_type<T> as = {};
}
Live On Coliru
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)