boost mpl fold占位符表达式无法编译

时间:2015-02-13 10:13:38

标签: c++ boost fold boost-mpl

我正在尝试从boost-mpl(位于libs / mpl / examples / fsm / player2.cpp中)编译Statemachine示例,但它在boost版本1.37和g ++ 4.8.2中失败。使用boost版本1.56和相同的编译器,构建成功。不幸的是,由于某些平台限制,我无法切换到1.56版本。

我不希望任何人查看上面提到的冗长示例,因此我找到了一个最小的代码片段来说明问题:

#include <boost/mpl/fold.hpp>
#include <boost/mpl/vector.hpp>
#include <boost/mpl/placeholders.hpp>

namespace mpl = boost::mpl;
using namespace mpl::placeholders;

//Basic queue datatype
template< class CURRENT, class NEXT >
struct queue_element
{
    typedef typename CURRENT::mytype mytype;
};

//type to be put at the end of the queue
struct default_queue_element
{
};

template <class TYPE>
struct wrapper{
    typedef TYPE mytype;
};

typedef mpl::vector<wrapper<int>, wrapper<char> > myvector;

//the following fold expression should create this type:
typedef queue_element<wrapper<char>, queue_element<wrapper<int>,
default_queue_element> > this_type_should_be_created;

//This typedef fails to compile with boost Version 1.37,
//but works perfectly with version 1.56
typedef typename
mpl::fold<
    myvector
    ,default_queue_element
    ,queue_element<_2,_1>
>::type
generate_queue;

使用boost 1.37,g ++会发出以下错误:

foldtest2.cpp: In instantiation of ‘struct queue_element<mpl_::arg<2>, mpl_::arg<1> >’:
../boost_1_37_0/boost/mpl/aux_/preprocessed/gcc/template_arity.hpp:85:5:   required from ‘const int boost::mpl::aux::template_arity_impl<queue_element<mpl_::arg<2>, mpl_::arg<1> >, 1>::value’
../boost_1_37_0/boost/mpl/aux_/preprocessed/gcc/template_arity.hpp:93:5:   required from ‘const int boost::mpl::aux::template_arity<queue_element<mpl_::arg<2>, mpl_::arg<1> > >::value’
../boost_1_37_0/boost/mpl/aux_/preprocessed/gcc/template_arity.hpp:98:30:   required from ‘struct boost::mpl::aux::template_arity<queue_element<mpl_::arg<2>, mpl_::arg<1> > >’
../boost_1_37_0/boost/mpl/aux_/preprocessed/gcc/apply.hpp:67:8:   required from ‘struct boost::mpl::apply2<queue_element<mpl_::arg<2>, mpl_::arg<1> >, default_queue_element, wrapper<int> >’
../boost_1_37_0/boost/mpl/aux_/preprocessed/gcc/fold_impl.hpp:67:85:   required from ‘struct boost::mpl::aux::fold_impl<2, boost::mpl::v_iter<boost::mpl::vector<wrapper<int>, wrapper<char> >, 0l>, boost::mpl::v_iter<boost::mpl::vector<wrapper<int>, wrapper<char> >, 2l>, default_queue_element, queue_element<mpl_::arg<2>, mpl_::arg<1> > >’
../boost_1_37_0/boost/mpl/fold.hpp:39:18:   required from ‘struct boost::mpl::fold<boost::mpl::vector<wrapper<int>, wrapper<char> >, default_queue_element, queue_element<mpl_::arg<2>, mpl_::arg<1> > >’
foldtest2.cpp:39:6:   required from here
foldtest2.cpp:15:38: error: no type named ‘mytype’ in ‘struct mpl_::arg<2>’
     typedef typename CURRENT::mytype mytype;

是否有解决方法使用boost 1.37编译代码?我一直在网上搜索一段时间。尽管如此问题已在某个地方得到解答,如果你能指出这一点,我将不胜感激。

1 个答案:

答案 0 :(得分:2)

看起来很简单就是那个古老的(¹)版本的增强版中的一个错误。

快速二分告诉我它已在v1.43.0(²)中修复。 Release notes不要透露这个秘密,但是git会这样做:

显然似乎是后者(通过编译31a2c78证实)。

所以你在include / boost / mpl / aux_ / template_arity.hpp(³)修复这一行:

sizeof(arity_helper(type_wrapper<F>(),arity_tag<N>())) - 1

应该是

sizeof(::boost::mpl::aux::arity_helper(type_wrapper<F>(),arity_tag<N>())) - 1

当然,解决此问题的正确方法是使用受支持的boost版本


¹(2008年11月3日)!!

²(2010年5月6日)

³警告:也出现在标题的预处理版本中生成的多个副本