// // 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_DEQUE_HPP #define BOOST_PTR_CONTAINER_PTR_DEQUE_HPP #if defined(_MSC_VER) && (_MSC_VER >= 1200) # pragma once #endif #include <deque> #include <boost/ptr_container/ptr_sequence_adapter.hpp> namespace boost { template < class T, class CloneAllocator = heap_clone_allocator, class Allocator = std::allocator<void*> > class ptr_deque : public ptr_sequence_adapter< T, std::deque<void*,Allocator>, CloneAllocator > { typedef ptr_sequence_adapter< T, std::deque<void*,Allocator>, CloneAllocator > base_class; typedef ptr_deque<T,CloneAllocator,Allocator> this_type; public: BOOST_PTR_CONTAINER_DEFINE_SEQEUENCE_MEMBERS( ptr_deque, base_class, this_type ) }; ////////////////////////////////////////////////////////////////////////////// // clonability template< typename T, typename CA, typename A > inline ptr_deque<T,CA,A>* new_clone( const ptr_deque<T,CA,A>& r ) { return r.clone().release(); } ///////////////////////////////////////////////////////////////////////// // swap template< typename T, typename CA, typename A > inline void swap( ptr_deque<T,CA,A>& l, ptr_deque<T,CA,A>& r ) { l.swap(r); } } #endif