data:image/s3,"s3://crabby-images/68a92/68a92ef5f9509ed861931148198f5863404947f6" alt=""
Thank you, Watanabe. B/Rgds Max ----- Original Message ----- From: Steven Watanabe To: boost-users@lists.boost.org Subject: Re: [Boost-users] [iterator] transform_iterator Date: 2008-12-25 00:47:36 AMDG Max wrote:
I just came across transform_iterator and found it a useful generic tool. But is it possible for it to go further to make the following code get compiled and run as expected?
No.
struct A { int i_; A() : i_(0) {} explicit A(int i) : i_(i) {} };
const int N = 5; A a_list[N] = { A(-3), A(1), A(3), A(2), A(-4) };
typedef boost::function fn_t;
// sorting a_list according to the elements' i_ member std::stable_sort(boost::make_transform_iterator(a_list, fn_t(boost::bind(&A::i_, _1))), boost::make_transform_iterator(a_list+N, fn_t(boost::bind(&A::i_, _1))), std::less());
stable_sort assumes that the sort keys are the same as the objects that it is moving around. In Christ, Steven Watanabe ------------------------------------------------------------------- 新浪空间——与朋友开心分享网络新生活!(http://space.sina.com.cn/ )