///////////////////////////////////////////////////////////////////////////// // // (C) Copyright Ion Gaztanaga 2006-2007 // // Distributed under the Boost Software License, Version 1.0. // (See accompanying file LICENSE_1_0.txt or copy at // http://www.boost.org/LICENSE_1_0.txt) // // See http://www.boost.org/libs/intrusive for documentation. // ///////////////////////////////////////////////////////////////////////////// //[doc_how_to_use_code #include #include using namespace boost::intrusive; class MyClass : public list_base_hook<> { int int_; public: list_member_hook<> member_hook_; MyClass(int i) : int_(i) {} int get() const { return int_; } }; //Define a list that will store MyClass using the base hook typedef list< list_base_hook<>::value_traits > BaseList; //Define a list that will store MyClass using the member hook typedef list< list_member_hook<>:: value_traits > MemberList; int main() { typedef std::vector Vect; typedef Vect::iterator VectIt; typedef Vect::reverse_iterator VectRit; //Create several MyClass objects, each one //with a different internal number Vect myclassvector; for(int i = 0; i < 100; ++i) myclassvector.push_back(MyClass(i)); BaseList baselist; MemberList memberlist; //Now insert them in the reverse order //in the base hook intrusive list for(VectIt it(myclassvector.begin()), itend(myclassvector.end()) ; it != itend ; ++it){ baselist.push_front(*it); } //Now insert them in the same order as in vector in the //member hook intrusive list for(VectIt it(myclassvector.begin()), itend(myclassvector.end()) ; it != itend; ++it){ memberlist.push_back(*it); } //Now test lists { BaseList::reverse_iterator rbit(baselist.rbegin()), rbitend(baselist.rend()); MemberList::iterator mit(memberlist.begin()), mitend(memberlist.end()); VectIt it(myclassvector.begin()), itend(myclassvector.end()); //Test the objects inserted in the base hook list for(; it != itend; ++it, ++rbit){ if(&*rbit != &*it) return 1; } //Test the objects inserted in the member hook list for(it = myclassvector.begin(); it != itend; ++it, ++mit){ if(&*mit != &*it) return 1; } } return 0; } //]