| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 | //// 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
 |