++++++++++++++++++++++++++++++++++ |Boost| Pointer Container Library ++++++++++++++++++++++++++++++++++ .. |Boost| image:: boost.png Class ``ptr_list`` ------------------ A ``ptr_list`` is a pointer container that uses an underlying ``std:list`` to store the pointers. **Hierarchy:** - `reversible_ptr_container `_ - `ptr_sequence_adapter `_ - `ptr_vector `_ - ``ptr_list`` - `ptr_deque `_ - `ptr_array `_ **Navigate:** - `home `_ - `reference `_ **Synopsis:** .. parsed-literal:: 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 > { public: // modifiers_ void push_front( T* x ); template< class U > void push_front( std::auto_ptr x ); auto_type pop_front(); public: // `list operations`_ void reverse(); }; // class 'ptr_list' } // namespace 'boost' Semantics --------- .. _modifiers: Semantics: modifiers ^^^^^^^^^^^^^^^^^^^^ - ``void push_front( T* x );`` - Requirements: ``x != 0`` - Effects: Inserts the pointer into container and takes ownership of it - Throws: ``bad_pointer`` if ``x == 0`` - Exception safety: Strong guarantee - ``template< class U > void push_front( std::auto_ptr x );`` - Effects: ``push_front( x.release() );`` .. - ``void push_front( const T& x );`` - Effects: push_front( allocate_clone( x ) ); - Exception safety: Strong guarantee - ``auto_type pop_front():`` - Requirements:``not empty()`` - Effects: Removes the first element in the container - Postconditions: ``size()`` is one less - Throws: ``bad_ptr_container_operation`` if ``empty() == true`` - Exception safety: Strong guarantee .. _`list operations`: Semantics: list operations ^^^^^^^^^^^^^^^^^^^^^^^^^^ .. - ``void splice( iterator before, ptr_list& x );`` - Requirements:``&x != this`` - Effects: inserts the all of ``x``'s elements before ``before`` - Postconditions: ``x.empty()`` - Throws: nothing - Remark: prefer this to ``transfer( before, x );`` - ``void splice( iterator before, ptr_list& x, iterator i );`` - Not ready yet - ``void splice( iterator before, ptr_list& x, iterator first, iterator last );`` - Not ready yet - ``void merge( ptr_list& x );`` - Not ready yet - ``template< typename Compare > void merge( ptr_list& x, Compare comp );`` - Not ready yet - ``void reverse();`` - Effects: reverses the underlying sequence - Throws: nothing .. raw:: html
:Copyright: Thorsten Ottosen 2004-2006. Use, modification and distribution is subject to the Boost Software License, Version 1.0 (see LICENSE_1_0.txt__). __ http://www.boost.org/LICENSE_1_0.txt