// // Boost.Pointer Container // // Copyright Thorsten Ottosen 2003-2005. Use, modification and // distribution is subject to 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) // // For more information, see http://www.boost.org/libs/ptr_container/ // #ifndef BOOST_PTR_CONTAINER_PTR_LIST_HPP #define BOOST_PTR_CONTAINER_PTR_LIST_HPP #if defined(_MSC_VER) && (_MSC_VER >= 1200) # pragma once #endif #include #include namespace boost { template < class T, class CloneAllocator = heap_clone_allocator, class Allocator = std::allocator > class ptr_list : public ptr_sequence_adapter< T, std::list, CloneAllocator > { typedef ptr_sequence_adapter< T, std::list, CloneAllocator > base_class; typedef ptr_list this_type; public: BOOST_PTR_CONTAINER_DEFINE_SEQEUENCE_MEMBERS( ptr_list, base_class, this_type ); public: using base_class::merge; void merge( ptr_list& x ) { merge( x, std::less() ); } template< typename Compare > void merge( ptr_list& x, Compare comp ) { this->base().merge( x.base(), void_ptr_indirect_fun( comp ) ); } void sort() { sort( std::less() ); }; template< typename Compare > void sort( Compare comp ) { this->base().sort( void_ptr_indirect_fun( comp ) ); } }; // class 'ptr_list' ////////////////////////////////////////////////////////////////////////////// // clonability template< typename T, typename CA, typename A > inline ptr_list* new_clone( const ptr_list& r ) { return r.clone().release(); } ///////////////////////////////////////////////////////////////////////// // swap template< typename T, typename CA, typename A > inline void swap( ptr_list& l, ptr_list& r ) { l.swap(r); } } #endif