c++ - 从 Boost.Spirit.Qi 制作shared_ptr

标签 c++ parsing boost shared-ptr boost-spirit-qi

我想使用 Spirit Qi 语法将文本解析为指向字符串的共享指针。实际上,我想将多元多项式解析为一个系统,多项式中出现各种以前遇到的符号,但现在,让我们从文本解析为 std::shared_ptr<std::string>

我已经苦苦挣扎了很长一段时间,并在头文件中提炼了这个小测试语法:

#define BOOST_SPIRIT_USE_PHOENIX_V3 1

#include <boost/spirit/include/qi.hpp>
#include <boost/spirit/include/phoenix.hpp>
#include <boost/spirit/include/phoenix_operator.hpp>
#include <boost/bind.hpp>


namespace qi = boost::spirit::qi;
namespace ascii = boost::spirit::ascii;

template<typename Iterator>
struct SharedPtrParser :  qi::grammar<Iterator, std::shared_ptr<std::string>(), boost::spirit::ascii::space_type>
{
    SharedPtrParser() : SharedPtrParser(startrule)
    {
        startrule = qi::eps[ qi::_val = std::make_shared<std::string>()];
    }

    qi::rule<Iterator,std::shared_ptr<std::string>()> startrule;
};

以及它在 main 中的用法:

#include "shared_ptr_test.h"

int main()
{



    SharedPtrParser<std::string::const_iterator> C;

    std::string text = "thisissometext";

    auto iter = text.begin();
    auto end = text.end();


    std::shared_ptr<std::string> S;

    bool s = phrase_parse(iter, end, C,boost::spirit::ascii::space, S);


    return 0;
}

我知道我的语法不适合深蹲。我现在只想分享 Qi 的指点!为此,我发现了许多有关将智能指针与 Qi 结合使用的提示,但没有找到它们的工厂语法。我觉得我已经很接近了,尤其是发现this由 sehe 在 Spirit General 论坛上发表的帖子。但是,我还无法将它们组合在一起。

编译尝试会产生两个 ATM 写入错误。

一:

./shared_ptr_test.h:16:22: error: no matching constructor for initialization of 'SharedPtrParser<std::__1::__wrap_iter<const char *> >'
        SharedPtrParser() : SharedPtrParser(startrule)
                            ^               ~~~~~~~~~
shared_ptr_test.cpp:8:47: note: in instantiation of member function 'SharedPtrParser<std::__1::__wrap_iter<const char *> >::SharedPtrParser' requested here
        SharedPtrParser<std::string::const_iterator> C;
                                                     ^
./shared_ptr_test.h:14:8: note: candidate constructor (the implicit copy constructor) not viable: no known conversion from 'qi::rule<__wrap_iter<const char *>,
      std::shared_ptr<std::string> ()>' to 'const SharedPtrParser<std::__1::__wrap_iter<const char *> >' for 1st argument
struct SharedPtrParser :  qi::grammar<Iterator, std::shared_ptr<std::string>(), boost::spirit::ascii::space_type>
       ^
./shared_ptr_test.h:16:2: note: candidate constructor not viable: requires 0 arguments, but 1 was provided
        SharedPtrParser() : SharedPtrParser(startrule)
        ^

两个:

In file included from shared_ptr_test.cpp:1:
In file included from ./shared_ptr_test.h:4:
In file included from /usr/local/include/boost/spirit/include/qi.hpp:16:
In file included from /usr/local/include/boost/spirit/home/qi.hpp:21:
In file included from /usr/local/include/boost/spirit/home/qi/nonterminal.hpp:14:
In file included from /usr/local/include/boost/spirit/home/qi/nonterminal/rule.hpp:35:
/usr/local/include/boost/spirit/home/qi/reference.hpp:43:30: error: no matching member function for call to 'parse'
            return ref.get().parse(first, last, context, skipper, attr_);
                   ~~~~~~~~~~^~~~~
/usr/local/include/boost/spirit/home/qi/parse.hpp:164:40: note: in instantiation of function template specialization 'boost::spirit::qi::reference<const
      boost::spirit::qi::rule<std::__1::__wrap_iter<const char *>, std::__1::shared_ptr<std::__1::basic_string<char> > (),
      boost::proto::exprns_::expr<boost::proto::tagns_::tag::terminal, boost::proto::argsns_::term<boost::spirit::tag::char_code<boost::spirit::tag::space,
      boost::spirit::char_encoding::ascii> >, 0>, boost::spirit::unused_type, boost::spirit::unused_type> >::parse<std::__1::__wrap_iter<char *>,
      boost::spirit::context<boost::fusion::cons<std::__1::shared_ptr<std::__1::basic_string<char> > &, boost::fusion::nil_>, boost::spirit::locals<mpl_::na, mpl_::na, mpl_::na,
      mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na> >, boost::spirit::qi::char_class<boost::spirit::tag::char_code<boost::spirit::tag::space,
      boost::spirit::char_encoding::ascii> >, std::__1::shared_ptr<std::__1::basic_string<char> > >' requested here
        if (!compile<qi::domain>(expr).parse(
                                       ^
/usr/local/include/boost/spirit/home/qi/parse.hpp:197:20: note: in instantiation of function template specialization 'boost::spirit::qi::phrase_parse<std::__1::__wrap_iter<char *>,
      SharedPtrParser<std::__1::__wrap_iter<const char *> >, boost::proto::exprns_::expr<boost::proto::tagns_::tag::terminal,
      boost::proto::argsns_::term<boost::spirit::tag::char_code<boost::spirit::tag::space, boost::spirit::char_encoding::ascii> >, 0>, std::__1::shared_ptr<std::__1::basic_string<char>
      > >' requested here
        return qi::phrase_parse(first, last, expr, skipper, skip_flag::postskip, attr);
                   ^
shared_ptr_test.cpp:18:11: note: in instantiation of function template specialization 'boost::spirit::qi::phrase_parse<std::__1::__wrap_iter<char *>,
      SharedPtrParser<std::__1::__wrap_iter<const char *> >, boost::proto::exprns_::expr<boost::proto::tagns_::tag::terminal,
      boost::proto::argsns_::term<boost::spirit::tag::char_code<boost::spirit::tag::space, boost::spirit::char_encoding::ascii> >, 0>, std::__1::shared_ptr<std::__1::basic_string<char>
      > >' requested here
        bool s = phrase_parse(iter, end, C,boost::spirit::ascii::space, S);
                 ^
/usr/local/include/boost/spirit/home/qi/nonterminal/rule.hpp:274:14: note: candidate function [with Context =
      boost::spirit::context<boost::fusion::cons<std::__1::shared_ptr<std::__1::basic_string<char> > &, boost::fusion::nil_>, boost::spirit::locals<mpl_::na, mpl_::na, mpl_::na,
      mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na> >, Skipper = boost::spirit::qi::char_class<boost::spirit::tag::char_code<boost::spirit::tag::space,
      boost::spirit::char_encoding::ascii> >, Attribute = std::__1::shared_ptr<std::__1::basic_string<char> >] not viable: no known conversion from 'std::__1::__wrap_iter<char *>' to
      'std::__1::__wrap_iter<const char *> &' for 1st argument
        bool parse(Iterator& first, Iterator const& last
             ^
/usr/local/include/boost/spirit/home/qi/nonterminal/rule.hpp:320:14: note: candidate function template not viable: requires 6 arguments, but 5 were provided
        bool parse(Iterator& first, Iterator const& last

有一点帮助吗?

最佳答案

我的问题既微不足道又新手。我未能指定构造函数 ::base_type。也就是说, SharedPtrParser() : SharedPtrParser(startrule) 的行应该是 SharedPtrParser() : SharedPtrParser::base_type(startrule)

关于c++ - 从 Boost.Spirit.Qi 制作shared_ptr,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30464410/

相关文章:

python - python相对xml节点遍历

php - PHP解析/语法错误;以及如何解决它们

c++ - boost::带有 bool 和 string 的变体

c++ - 在 C++ 中迭代 std::map 的键/值

c++ - 如何将模板化 vector 传递给 C++ 函数?

c++ - 使用继承时未解析的引用

java - 将非 ISO 8601 解析为 ISO_INSTANT

c++ - deadline_timer::wait 是否屈服于其他任务?

c++ - 对 'dlsym' 的 undefined reference

c++ - std::unordered_map 不断导致错误,这是一个错误吗?