2011-10-30 91 views
0

我试图编写一个类似于boost :: mpl :: find_if的元函数,但区别在于它将遍历从结尾开始的序列。我得到的编译错误,我认为来自计算的mpl :: lambda作为我的元函数的参数传递。我会非常感谢任何关于我做错事的指针。传递一个mpl lambda表达式作为模板参数

现在我想一个懒惰的解决方案(装饰原find_if):

#include <boost/mpl/reverse.hpp> 
#include <boost/mpl/find_if.hpp> 
#include <boost/mpl/distance.hpp> 
#include <boost/mpl/begin_end.hpp> 
#include <boost/mpl/advance.hpp> 
#include <boost/mpl/next_prior.hpp> 
#include <boost/mpl/lambda.hpp> 


using boost::mpl::reverse; 
using boost::mpl::find_if; 
using boost::mpl::distance; 
using boost::mpl::end; 
using boost::mpl::advance; 
using boost::mpl::prior; 
using boost::mpl::lambda; 

template<typename SEQ, typename pred> 
struct rfind_if { 
private: 
    // find the element in the reversed container  
    typedef typename reverse<SEQ>::type rev_SEQ; 
    typedef typename lambda<pred>::type expanded_pred;  
    typedef typename find_if<rev_SEQ, expanded_pred>::type rev_iter; 
    // compute the distance of the iterator 
    typedef typename distance<rev_iter, typename end<rev_SEQ>::type >::type dist; 
public: 
    //compute the iterator 
    typedef typename advance<typename begin<SEQ>::type, typename prior<dist>::type>::type type; 
}; 

的问题是,当尝试使用此功能:

typedef vector_c<int, 1, 2, 3, 6, 5, 4>::type test_vect; 
typedef find<test_vect, int_<6>::type>::type it_cur; 
typedef rfind_if<test_vect, lambda<less<deref<it_cur>::type, _1> >::type >::type it_swap; 
std::cout << "it_swap=" << deref<it_swap>::type::value << "\n\n"; 

我得到神秘的错误,这些错误,我猜,来自lambda计算:

/usr/include/boost/mpl/aux_/preprocessed/gcc/less.hpp:60: error: no type named ‘tag’ in ‘struct mpl_::void_’ (some more template noise) 
/usr/include/boost/mpl/not.hpp:43: error: ‘value’ is not a member of ‘boost::mpl::aux::nested_type_wknd<boost::mpl::aux::iter_apply1 (some more template noise) 
/usr/include/boost/mpl/aux_/preprocessed/gcc/iter_fold_if_impl.hpp:62: error: no type named ‘type’ in ‘struct boost::mpl::apply2<boost::mpl::protect<boost::mpl::aux::iter_fold_if_pred (some more template noise) 
...and much more... 

我测试了rfi的内部nd_if(不通过lambda作为一个模板参数)和它的工作,命名:

typedef vector_c<int, 1, 2, 3, 6, 5, 4>::type    test_vect; 
typedef boost::mpl::reverse<test_vect>::type    rev_SEQ; 
typedef find_if<rev_SEQ, less<int_<5>, _1> >::type   rev_iter; 
typedef distance<rev_iter, end<rev_SEQ>::type >::type  dist; 
typedef advance<begin<test_vect>::type, prior<dist>::type>::type it_begin; 

boost::mpl::for_each<rev_SEQ>(value_printer()); 

产生正确的结果

我知道,我的功能还远远没有效率,但现在我想了解的问题。之后我会写一个适当的实施。

问候

回答

1

据我看到的,rfind_if是不是错误的原因,但在 代码中的问题似乎关联化test_vectend

1) 在vector_c<int>类型的元件的似乎integral_c<int>,不 int_。 所以find<test_vect, int_<6>::type>::typeendtest_vect。 因此,取消参考deref<it_cur>::type中的it_cur无效。

2) 如果你的意思less<int_<6>, _1>通过less<deref<it_cur>::type, _1>, 因为test_vect没有这样的元素,rfind_if<...>::type是 再次test_vectend。 因此在deref<it_swap>::type::value中取消引用无效。

修复上述问题后, 代码可以在ideone进行编译。

+0

谢谢,您的解释是有道理的,并提供解决方案。 – Marcin

+0

不客气:-) –

相关问题