4

以下代码不能g++ (GCC) 4.6.0 20110603 (prerelease)使用-std=c++0xand编译Boost 1.46.1。我错过了包含还是这实际上是一个错误?如果是后者,如何解决?

#include <boost/mpl/vector.hpp>
#include <boost/mpl/transform.hpp>
#include <boost/mpl/clear.hpp>

#include <boost/fusion/mpl.hpp>
#include <boost/fusion/include/clear.hpp>
#include <boost/fusion/include/clear.hpp>

#include <boost/fusion/adapted/boost_tuple.hpp>
#include <boost/fusion/include/boost_tuple.hpp>

namespace mpl = boost::mpl;

template<typename T>
struct Meta {
  T t;
  typedef mpl::vector<std::function<void(double)>, std::function<void(char)>, 
              std::function<void(int)>> MplVector;
  typedef T FusionSequence;

  //works
  typedef mpl::transform< MplVector, mpl::identity<mpl::_1> >::type result;
  //doesn't, work
  typedef typename mpl::transform< FusionSequence, mpl::identity<mpl::_1> >::type result2;
};

template<typename T>
Meta<T> make_meta(T t) { return Meta<T>({t}); }

int main()
{
  auto m = make_meta(boost::make_tuple(
               std::function<void(double)>([](double) { }),
               std::function<void(int)>([](int) { }),
               std::function<void(char)>([](char) { })));
}
4

2 回答 2

4

当您不提供插入器时,transform必须为您生成一个(结果必须在某处累积),这基本上相当于做类似back_inserter< clear<OriginalSequence>::type >. 这些transform文档在这里有些误导,因为它们没有记录算法的“无插入器”版本的这种额外要求。

于 2011-06-21T21:38:06.890 回答
2

如果你使用fusion::make_vector而不是 make_tuple,你可以使用mpl:: tranform 。关键的诀窍是也#include <boost/fusion/include/transform.hpp>!一个简单的例子如下:

#include <boost/fusion/include/transform.hpp>
#include <boost/fusion/container/vector.hpp>
#include <boost/mpl/transform.hpp>

// Only works if <boost/fusion/include/transform.hpp> is included:
typedef boost::fusion::vector<int> FusionVector;
typedef typename boost::mpl::transform<FusionVector, boost::mpl::_1>::type FusionTransformed;
于 2011-07-21T20:55:17.987 回答