// // 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_VECTOR_HPP #define BOOST_PTR_CONTAINER_PTR_VECTOR_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_vector : public ptr_sequence_adapter< T, std::vector, CloneAllocator > { typedef ptr_sequence_adapter< T, std::vector, CloneAllocator > base_class; typedef ptr_vector this_type; public: BOOST_PTR_CONTAINER_DEFINE_SEQEUENCE_MEMBERS( ptr_vector, base_class, this_type ) explicit ptr_vector( size_type n, const allocator_type& alloc = allocator_type() ) : base_class(alloc) { this->base().reserve( n ); } }; ////////////////////////////////////////////////////////////////////////////// // clonability template< typename T, typename CA, typename A > inline ptr_vector* new_clone( const ptr_vector& r ) { return r.clone().release(); } ///////////////////////////////////////////////////////////////////////// // swap template< typename T, typename CA, typename A > inline void swap( ptr_vector& l, ptr_vector& r ) { l.swap(r); } } #endif