How can I use the skipper ascii::space WITHOUT skipping eol?(如何在不跳过 eol 的情况下使用船长 ascii::space?)
问题描述
我必须使用 boost::spirit 进行解析,我想使用phrase_parse 函数:
I have to use boost::spirit for parsing, and I want use phrase_parse function :
qi::phrase_parse(str.begin(), str.end(), grammar, ascii::space - qi::eol);
但是我的编译器不允许第四项(ascii::space - qi::eol).如何在不跳过 eol 的情况下使用船长 ascii::space ?
But the fourth term (ascii::space - qi::eol), isnt allowed by my compiler. How can I use the skipper ascii::space WITHOUT skipping eol ?
推荐答案
最简单的答案是
qi::phrase_parse(str.begin(), str.end(), grammar, ascii::blank);
当然,这也取决于你的语法:如果它需要一个特定的船长类,你可能需要改变它.请参阅下面的通用处理方式(尽管您可以只为只接受 的语法指定
).qi::blank_type
qi::blank
Of course, it depends on your grammar too: if it expects a specific skipper class you might need to change that. See below for a generic way to handle that (although you could just specify qi::blank_type
for a Grammar that should only accept qi::blank
).
该示例也处理任意跳过程序.
The sample handles arbitrary skippers too.
Spirit 有几个指令会影响船长的使用:
Spirit has several directives that influence the use of skippers:
qi::lexeme
将解析子表达式而不考虑船长(对于例如语法中的字符串文字很有用)
will parse the sub-expression regardless of skipper (useful for e.g. string literals in a grammar)
qi::raw
将返回原始源迭代器范围,这意味着跳过的输入将包含在结果中
will return the raw source iterator range, meaning that skipped input will be included in the result
qi::no_skip
, qi::skip
可用于显式更改用于子表达式的船长类型
can be used to explicitely change the type of skipper used for the subexpression
Boost Spirit 网站上有一篇关于此类内容的好文章
The Boost Spirit site has a nice article about things like this
- 解析船长和跳过解析器
#include <boost/spirit/include/qi.hpp>
namespace qi = boost::spirit::qi;
template <typename It, typename Skipper>
struct parser : qi::grammar<It, Skipper>
{
parser() : parser::base_type(start)
{
start = *qi::int_;
}
private:
qi::rule<It, Skipper> start;
};
template <typename C, typename Skipper>
void doParse(const C& input, const Skipper& skipper)
{
auto f(std::begin(input)), l(std::end(input));
parser<decltype(f), Skipper> p;
bool ok = qi::phrase_parse(f,l,p,skipper);
if (ok)
std::cout << "parse success
";
}
int main()
{
const std::string input = "1 2 3 4";
doParse(input, qi::blank);
doParse(input, qi::space);
doParse(input, ~qi::char_("0-9"));
}
这篇关于如何在不跳过 eol 的情况下使用船长 ascii::space?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:如何在不跳过 eol 的情况下使用船长 ascii::space?
基础教程推荐
- 使用从字符串中提取的参数调用函数 2022-01-01
- Windows Media Foundation 录制音频 2021-01-01
- 如何“在 Finder 中显示"或“在资源管理器中显 2021-01-01
- 如何使图像调整大小以在 Qt 中缩放? 2021-01-01
- 在 C++ 中循环遍历所有 Lua 全局变量 2021-01-01
- 从 std::cin 读取密码 2021-01-01
- 管理共享内存应该分配多少内存?(助推) 2022-12-07
- 如何在不破坏 vtbl 的情况下做相当于 memset(this, ...) 的操作? 2022-01-01
- 为什么语句不能出现在命名空间范围内? 2021-01-01
- 为 C/C++ 中的项目的 makefile 生成依赖项 2022-01-01