// // Boost.Pointer Container // // Copyright Thorsten Ottosen 2008. 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_INSERTER_HPP #define BOOST_PTR_CONTAINER_PTR_INSERTER_HPP #if defined(_MSC_VER) && (_MSC_VER >= 1200) #pragma once #endif #include <boost/config.hpp> #include <iterator> #include <memory> namespace boost { namespace ptr_container { template< class PtrContainer > class ptr_back_insert_iterator; template< class PtrContainer > class ptr_front_insert_iterator; template< class PtrContainer > class ptr_insert_iterator; template< class PtrContainer > ptr_back_insert_iterator<PtrContainer> ptr_back_inserter( PtrContainer& cont ); template< class PtrContainer > ptr_front_insert_iterator<PtrContainer> ptr_front_inserter( PtrContainer& cont ); template< class PtrContainer > ptr_insert_iterator<PtrContainer> ptr_inserter( PtrContainer& cont, typename PtrContainer::iterator before ); ////////////////////////////////////////////////////////////////////////// // Implementation ////////////////////////////////////////////////////////////////////////// template< class PtrContainer > class ptr_back_insert_iterator : public std::iterator<std::output_iterator_tag,void,void,void,void> { public: typedef PtrContainer container_type; public: explicit ptr_back_insert_iterator( PtrContainer& cont ) : container(&cont) { } ptr_back_insert_iterator& operator=( typename PtrContainer::value_type r ) { typename PtrContainer::value_type obj = 0; if( r != 0 ) obj = container_type::clone_allocator_type::allocate_clone(*r); container->push_back( obj ); return *this; } template< class T > ptr_back_insert_iterator& operator=( std::auto_ptr<T> r ) { container->push_back( r ); return *this; } ptr_back_insert_iterator& operator=( typename PtrContainer::const_reference r ) { container->push_back( container_type::clone_allocator_type:: allocate_clone(r) ); return *this; } ptr_back_insert_iterator& operator*() { return *this; } ptr_back_insert_iterator& operator++() { return *this; } ptr_back_insert_iterator operator++(int) { return *this; } protected: PtrContainer* container; }; template< class PtrContainer > class ptr_front_insert_iterator : public std::iterator<std::output_iterator_tag,void,void,void,void> { public: typedef PtrContainer container_type; public: explicit ptr_front_insert_iterator( PtrContainer& cont ) : container(&cont) { } ptr_front_insert_iterator& operator=( typename PtrContainer::value_type r ) { typename PtrContainer::value_type obj = 0; if( r != 0 ) obj = container_type::clone_allocator_type::allocate_clone(*r); container->push_front( obj ); return *this; } template< class T > ptr_front_insert_iterator& operator=( std::auto_ptr<T> r ) { container->push_front( r ); return *this; } ptr_front_insert_iterator& operator=( typename PtrContainer::const_reference r ) { container->push_front( container_type::clone_allocator_type:: allocate_clone(r) ); return *this; } ptr_front_insert_iterator& operator*() { return *this; } ptr_front_insert_iterator& operator++() { return *this; } ptr_front_insert_iterator operator++(int) { return *this; } protected: PtrContainer* container; }; template< class PtrContainer > class ptr_insert_iterator : public std::iterator<std::output_iterator_tag,void,void,void,void> { public: typedef PtrContainer container_type; public: ptr_insert_iterator( PtrContainer& cont, typename PtrContainer::iterator before ) : container(&cont), iter(before) { } ptr_insert_iterator& operator=( typename PtrContainer::value_type r ) { typename PtrContainer::value_type obj = 0; if( r != 0 ) obj = container_type::clone_allocator_type::allocate_clone(*r); iter = container->insert( iter, obj ); return *this; } template< class T > ptr_insert_iterator& operator=( std::auto_ptr<T> r ) { iter = container->insert( iter, r ); return *this; } ptr_insert_iterator& operator=( typename PtrContainer::const_reference r ) { iter = container->insert( iter, container_type::clone_allocator_type:: allocate_clone(r) ); return *this; } ptr_insert_iterator& operator*() { return *this; } ptr_insert_iterator& operator++() { return *this; } ptr_insert_iterator operator++(int) { return *this; } protected: PtrContainer* container; typename PtrContainer::iterator iter; }; template< class PtrContainer > inline ptr_back_insert_iterator<PtrContainer> ptr_back_inserter( PtrContainer& cont ) { return ptr_back_insert_iterator<PtrContainer>( cont ); } template< class PtrContainer > inline ptr_front_insert_iterator<PtrContainer> ptr_front_inserter( PtrContainer& cont ) { return ptr_front_insert_iterator<PtrContainer>( cont ); } template< class PtrContainer > inline ptr_insert_iterator<PtrContainer> ptr_inserter( PtrContainer& cont, typename PtrContainer::iterator before ) { return ptr_insert_iterator<PtrContainer>( cont, before ); } } // namespace 'ptr_container' } // namespace 'boost' #endif