到目前为止,我有一个语法一直在使用标准的boost::spirit::ascii::space/boost::spirit::ascii::space_type船长。我有一些使用船长的规则和一些不使用的规则,比如qi::rule(),ascii::space_type>expression;qi::rule()>term;当我在跳跃式非终结符(如expression)内部使用非跳跃式非终结符(如term)时,一切都像我期望的那样工作-空格只在内部起作用term非终结符。此外,到目前为止,我一直很好地包括在不使用qi::skip重新建立跳过的非终端内部使用skipper的非终端,例如in
不应该是一个简单的eol成功了吗?#include#include#include#includeusingboost::spirit::ascii::space;usingboost::spirit::lit;usingboost::spirit::qi::eol;usingboost::spirit::qi::phrase_parse;structfix:std::unary_function{fix(std::string&result):result(result){}voidoperator()(charc){if(c=='\n')result+="\\n";elseif(c
我正在为使用缩进等的相当复杂的配置文件编写解析器。我决定使用Lex将输入分解为标记,因为它似乎让生活更轻松。问题是我找不到任何将Qi错误报告工具(on_error)与对标记流而不是字符流进行操作的解析器一起使用的示例。要在on_error中使用的错误处理程序需要一些才能准确指示错误在输入流中的位置。所有例子都只是构造std::string从一对迭代器中打印出来。但是如果使用Lex,那么迭代器就是标记序列的迭代器,而不是字符。在我的程序中,这导致挂起std::string在我注意到无效的迭代器类型之前构造函数。据我所知,token可以将一对迭代器保存到输入流中作为它的值。这是默认属性类型
按照几个教程(例如http://boost-spirit.com/home/articles/qi-example/nabialek-trick/),我想使用Nabialek技巧来拥有一个动态解析器。解析已经可以正常工作,但我没有得到传输的属性。解释如https://stackoverflow.com/a/9109972/2524462建议,属性应该是可能的,但不是参数。这只是一个将字符串和数字解析为结构的小示例。这只是为了展示我的问题;这种方法应该在以后真正需要动态解析器的更大系统中使用。问题:如何使用Nabialek技巧传输属性?我不是精神专家,所以请多多包涵。我正在使用g
这可能很明显,但是为什么boost中基于流的解析会重复最后一个字母呢?我一定是做错了什么:#include#include#includenamespaceqi=boost::spirit::qi;intmain(){std::stringinput="hello";std::stringstreamss(input);std::stringr1,r2;boost::spirit::istream_iteratorfirst(ss),last;qi::phrase_parse(input.begin(),input.end(),qi::lexeme[qi::alpha>>*qi::al