#include <iostream>
#include <boost/fusion/mpl.hpp>
#include <boost/fusion/include/mpl.hpp>
#include <boost/fusion/container/set.hpp>
#include <boost/fusion/include/at_key.hpp>
#include <boost/fusion/include/as_set.hpp>
#include <boost/mpl/vector.hpp>
#include <boost/mpl/set.hpp>
#include <boost/mpl/front.hpp>
#include <boost/mpl/fold.hpp>
#include <boost/mpl/placeholders.hpp>
#include <boost/mpl/insert.hpp>
struct node_base
{
int get() {return 123;}
};
struct node_a : public node_base
{};
struct node_b : public node_base
{};
struct node_c : public node_base
{};
typedef boost::mpl::vector3<
::boost::mpl::vector1<node_a>
,::boost::mpl::vector1<node_b>
,::boost::mpl::vector1<node_c>
>::type nested_vec_type;
typedef ::boost::mpl::fold<
nested_vec_type
, ::boost::mpl::set<>
, ::boost::mpl::insert<
::boost::mpl::placeholders::_1
, ::boost::mpl::front<::boost::mpl::placeholders::_2>
>
>::type restored_set_type;
typedef ::boost::fusion::result_of::as_set<restored_set_type> restored_fusion_set;
restored_fusion_set my_restored_set;
int main()
{
std::cout << boost::fusion::at_key<node_a>(my_restored_set).get() << std::endl;
std::cout << boost::fusion::at_key<node_b>(my_restored_set).get() << std::endl;
std::cout << boost::fusion::at_key<node_c>(my_restored_set).get() << std::endl;
return 0;
}
error C2039: 'category' : is not a member of 'boost::fusion::result_of::as_set<Sequence>'
error C2039: 'type' : is not a member of 'boost::fusion::result_of::end<Sequence>'
error C2504: 'boost::fusion::extension::end_impl<Tag>::apply<Sequence>' : base class undefined
error C2039: 'type' : is not a member of 'boost::fusion::result_of::begin<Sequence>'
error C2504: 'boost::fusion::extension::begin_impl<Tag>::apply<Sequence>' : base class undefined
error C2065: 'type' : undeclared identifier
来自简单mpl序列的转换,例如:: boost :: mpl :: vector&lt; node_a,node_b,node_c&gt;融合序列工作正常。 但是当我试图将经过处理的mpl序列从复杂的mpl序列(如嵌套的mpl矢量)转换为融合序列(通过result_of :: as_set或as_vector)时,我得到了编译时错误。
“restored_set_type”的打印输出为:
struct node_c
struct node_b
struct node_a
,但它似乎丢失了一些类型信息,这使得它与简单的mpl sequence :: boost :: mpl :: vector&lt; node_c,node_b,node_a&gt;
我是否遗漏了任何要指定的内容,例如标签,尺寸或?谢谢!
答案 0 :(得分:1)
解决方案比首次出现的要简单得多! :)
你错过了一些关键的东西:
typedef ::boost::fusion::result_of::as_set<restored_set_type> restored_fusion_set;
不正确,您需要的是:
typedef ::boost::fusion::result_of::as_set<restored_set_type>::type restored_fusion_set;
您只是错过了::type
,因此restored_fusion_set
的类型实际上是as_set<restored_set_type>
- 这不是必需的。