| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | /////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | //
 | 
					
						
							| 
									
										
										
										
											2009-10-14 11:59:32 +00:00
										 |  |  | // (C) Copyright Ion Gaztanaga 2007-2009
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | //
 | 
					
						
							|  |  |  | // Distributed under 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)
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // See http://www.boost.org/libs/intrusive for documentation.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | /////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | #ifndef BOOST_INTRUSIVE_AVL_SET_HPP
 | 
					
						
							|  |  |  | #define BOOST_INTRUSIVE_AVL_SET_HPP
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <boost/intrusive/detail/config_begin.hpp>
 | 
					
						
							|  |  |  | #include <boost/intrusive/intrusive_fwd.hpp>
 | 
					
						
							|  |  |  | #include <boost/intrusive/avltree.hpp>
 | 
					
						
							| 
									
										
										
										
											2008-12-13 13:55:44 +00:00
										 |  |  | #include <boost/intrusive/detail/mpl.hpp>
 | 
					
						
							| 
									
										
										
										
											2011-03-21 08:58:28 +00:00
										 |  |  | #include <boost/move/move.hpp>
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | #include <iterator>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace boost { | 
					
						
							|  |  |  | namespace intrusive { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  | //! The class template avl_set is an intrusive container, that mimics most of
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | //! the interface of std::set as described in the C++ standard.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  | //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | //! The template parameter \c T is the type to be managed by the container.
 | 
					
						
							|  |  |  | //! The user can specify additional options and if no options are provided
 | 
					
						
							|  |  |  | //! default options are used.
 | 
					
						
							|  |  |  | //!
 | 
					
						
							|  |  |  | //! The container supports the following options:
 | 
					
						
							|  |  |  | //! \c base_hook<>/member_hook<>/value_traits<>,
 | 
					
						
							|  |  |  | //! \c constant_time_size<>, \c size_type<> and
 | 
					
						
							|  |  |  | //! \c compare<>.
 | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | template<class T, class ...Options> | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | template<class Config> | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | class avl_set_impl | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |    /// @cond
 | 
					
						
							|  |  |  |    typedef avltree_impl<Config> tree_type; | 
					
						
							|  |  |  |    //! This class is
 | 
					
						
							| 
									
										
										
										
											2011-03-21 08:58:28 +00:00
										 |  |  |    //! movable
 | 
					
						
							|  |  |  |    BOOST_MOVABLE_BUT_NOT_COPYABLE(avl_set_impl) | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    typedef tree_type implementation_defined; | 
					
						
							|  |  |  |    /// @endcond
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    public: | 
					
						
							|  |  |  |    typedef typename implementation_defined::value_type               value_type; | 
					
						
							|  |  |  |    typedef typename implementation_defined::value_traits             value_traits; | 
					
						
							|  |  |  |    typedef typename implementation_defined::pointer                  pointer; | 
					
						
							|  |  |  |    typedef typename implementation_defined::const_pointer            const_pointer; | 
					
						
							|  |  |  |    typedef typename implementation_defined::reference                reference; | 
					
						
							|  |  |  |    typedef typename implementation_defined::const_reference          const_reference; | 
					
						
							|  |  |  |    typedef typename implementation_defined::difference_type          difference_type; | 
					
						
							|  |  |  |    typedef typename implementation_defined::size_type                size_type; | 
					
						
							|  |  |  |    typedef typename implementation_defined::value_compare            value_compare; | 
					
						
							|  |  |  |    typedef typename implementation_defined::key_compare              key_compare; | 
					
						
							|  |  |  |    typedef typename implementation_defined::iterator                 iterator; | 
					
						
							|  |  |  |    typedef typename implementation_defined::const_iterator           const_iterator; | 
					
						
							|  |  |  |    typedef typename implementation_defined::reverse_iterator         reverse_iterator; | 
					
						
							|  |  |  |    typedef typename implementation_defined::const_reverse_iterator   const_reverse_iterator; | 
					
						
							|  |  |  |    typedef typename implementation_defined::insert_commit_data       insert_commit_data; | 
					
						
							|  |  |  |    typedef typename implementation_defined::node_traits              node_traits; | 
					
						
							|  |  |  |    typedef typename implementation_defined::node                     node; | 
					
						
							|  |  |  |    typedef typename implementation_defined::node_ptr                 node_ptr; | 
					
						
							|  |  |  |    typedef typename implementation_defined::const_node_ptr           const_node_ptr; | 
					
						
							|  |  |  |    typedef typename implementation_defined::node_algorithms          node_algorithms; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
											
												Interprocess:
  [@https://svn.boost.org/trac/boost/ticket/3439 #3439],
  [@https://svn.boost.org/trac/boost/ticket/3846 #3846],
  [@https://svn.boost.org/trac/boost/ticket/3947 #3947],
  [@https://svn.boost.org/trac/boost/ticket/3985 #3985].
Intrusive:
  [@https://svn.boost.org/trac/boost/ticket/3668 #3668],
  [@https://svn.boost.org/trac/boost/ticket/3339 #3688],
  [@https://svn.boost.org/trac/boost/ticket/3698 #3698],
  [@https://svn.boost.org/trac/boost/ticket/3706 #3706],
  [@https://svn.boost.org/trac/boost/ticket/3721 #3721].
  [@https://svn.boost.org/trac/boost/ticket/3729 #3729],
  [@https://svn.boost.org/trac/boost/ticket/3746 #3746],
  [@https://svn.boost.org/trac/boost/ticket/3781 #3781],
  [@https://svn.boost.org/trac/boost/ticket/3829 #3829],
  [@https://svn.boost.org/trac/boost/ticket/3840 #3840],
  [@https://svn.boost.org/trac/boost/ticket/3339 #3339],
  [@https://svn.boost.org/trac/boost/ticket/3419 #3419],
  [@https://svn.boost.org/trac/boost/ticket/3431 #3431],
[SVN r60514]
											
										 
											2010-03-12 13:18:29 +00:00
										 |  |  |    static const bool constant_time_size = Config::constant_time_size; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    /// @cond
 | 
					
						
							|  |  |  |    private: | 
					
						
							|  |  |  |    tree_type tree_; | 
					
						
							|  |  |  |    /// @endcond
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    public: | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Effects</b>: Constructs an empty avl_set.
 | 
					
						
							|  |  |  |    //!  
 | 
					
						
							|  |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If value_traits::node_traits::node
 | 
					
						
							|  |  |  |    //!   constructor throws (this does not happen with predefined Boost.Intrusive hooks)
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!   or the copy constructor of the value_compare object throws.
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    avl_set_impl( const value_compare &cmp = value_compare() | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |            , const value_traits &v_traits = value_traits()) | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |       :  tree_(cmp, v_traits) | 
					
						
							|  |  |  |    {} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Requires</b>: Dereferencing iterator must yield an lvalue of type value_type.
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   cmp must be a comparison function that induces a strict weak ordering.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Constructs an empty avl_set and inserts elements from
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   [b, e).
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Complexity</b>: Linear in N if [b, e) is already sorted using
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   comp and otherwise N * log N, where N is std::distance(last, first).
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If value_traits::node_traits::node
 | 
					
						
							|  |  |  |    //!   constructor throws (this does not happen with predefined Boost.Intrusive hooks)
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!   or the copy constructor/operator() of the value_compare object throws.
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    template<class Iterator> | 
					
						
							|  |  |  |    avl_set_impl( Iterator b, Iterator e | 
					
						
							|  |  |  |            , const value_compare &cmp = value_compare() | 
					
						
							|  |  |  |            , const value_traits &v_traits = value_traits()) | 
					
						
							|  |  |  |       : tree_(true, b, e, cmp, v_traits) | 
					
						
							|  |  |  |    {} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-21 08:58:28 +00:00
										 |  |  |    //! <b>Effects</b>: to-do
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!  
 | 
					
						
							|  |  |  |    avl_set_impl(BOOST_RV_REF(avl_set_impl) x) | 
					
						
							| 
									
										
										
										
											2011-03-21 08:58:28 +00:00
										 |  |  |       :  tree_(::boost::move(x.tree_)) | 
					
						
							|  |  |  |    {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: to-do
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!  
 | 
					
						
							|  |  |  |    avl_set_impl& operator=(BOOST_RV_REF(avl_set_impl) x) | 
					
						
							| 
									
										
										
										
											2011-03-21 08:58:28 +00:00
										 |  |  |    {  tree_ = ::boost::move(x.tree_);  return *this;  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Effects</b>: Detaches all elements from this. The objects in the avl_set
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   are not deleted (i.e. no destructors are called).
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-11-18 10:43:35 +00:00
										 |  |  |    //! <b>Complexity</b>: Linear to the number of elements on the container.
 | 
					
						
							|  |  |  |    //!   if it's a safe-mode or auto-unlink value_type. Constant time otherwise.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    ~avl_set_impl() | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns an iterator pointing to the beginning of the avl_set.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    iterator begin() | 
					
						
							|  |  |  |    { return tree_.begin();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a const_iterator pointing to the beginning of the avl_set.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    const_iterator begin() const | 
					
						
							|  |  |  |    { return tree_.begin();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a const_iterator pointing to the beginning of the avl_set.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    const_iterator cbegin() const | 
					
						
							|  |  |  |    { return tree_.cbegin();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns an iterator pointing to the end of the avl_set.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    iterator end() | 
					
						
							|  |  |  |    { return tree_.end();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a const_iterator pointing to the end of the avl_set.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    const_iterator end() const | 
					
						
							|  |  |  |    { return tree_.end();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a const_iterator pointing to the end of the avl_set.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    const_iterator cend() const | 
					
						
							|  |  |  |    { return tree_.cend();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a reverse_iterator pointing to the beginning of the
 | 
					
						
							|  |  |  |    //!    reversed avl_set.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    reverse_iterator rbegin() | 
					
						
							|  |  |  |    { return tree_.rbegin();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a const_reverse_iterator pointing to the beginning
 | 
					
						
							|  |  |  |    //!    of the reversed avl_set.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    const_reverse_iterator rbegin() const | 
					
						
							|  |  |  |    { return tree_.rbegin();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a const_reverse_iterator pointing to the beginning
 | 
					
						
							|  |  |  |    //!    of the reversed avl_set.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    const_reverse_iterator crbegin() const | 
					
						
							|  |  |  |    { return tree_.crbegin();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a reverse_iterator pointing to the end
 | 
					
						
							|  |  |  |    //!    of the reversed avl_set.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    reverse_iterator rend() | 
					
						
							|  |  |  |    { return tree_.rend();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a const_reverse_iterator pointing to the end
 | 
					
						
							|  |  |  |    //!    of the reversed avl_set.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    const_reverse_iterator rend() const | 
					
						
							|  |  |  |    { return tree_.rend();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a const_reverse_iterator pointing to the end
 | 
					
						
							|  |  |  |    //!    of the reversed avl_set.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    const_reverse_iterator crend() const | 
					
						
							|  |  |  |    { return tree_.crend();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Precondition</b>: end_iterator must be a valid end iterator
 | 
					
						
							|  |  |  |    //!   of avl_set.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Returns a const reference to the avl_set associated to the end iterator
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							|  |  |  |    static avl_set_impl &container_from_end_iterator(iterator end_iterator) | 
					
						
							|  |  |  |    { | 
					
						
							|  |  |  |       return *detail::parent_from_member<avl_set_impl, tree_type> | 
					
						
							|  |  |  |          ( &tree_type::container_from_end_iterator(end_iterator) | 
					
						
							|  |  |  |          , &avl_set_impl::tree_); | 
					
						
							|  |  |  |    } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Precondition</b>: end_iterator must be a valid end const_iterator
 | 
					
						
							|  |  |  |    //!   of avl_set.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2008-04-27 15:03:06 +00:00
										 |  |  |    //! <b>Effects</b>: Returns a const reference to the set associated to the end iterator
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							|  |  |  |    static const avl_set_impl &container_from_end_iterator(const_iterator end_iterator) | 
					
						
							|  |  |  |    { | 
					
						
							|  |  |  |       return *detail::parent_from_member<avl_set_impl, tree_type> | 
					
						
							|  |  |  |          ( &tree_type::container_from_end_iterator(end_iterator) | 
					
						
							|  |  |  |          , &avl_set_impl::tree_); | 
					
						
							|  |  |  |    } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-27 15:03:06 +00:00
										 |  |  |    //! <b>Precondition</b>: it must be a valid iterator of set.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2008-04-27 15:03:06 +00:00
										 |  |  |    //! <b>Effects</b>: Returns a reference to the set associated to the iterator
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2008-04-27 15:03:06 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2008-04-27 15:03:06 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							|  |  |  |    static avl_set_impl &container_from_iterator(iterator it) | 
					
						
							|  |  |  |    { | 
					
						
							|  |  |  |       return *detail::parent_from_member<avl_set_impl, tree_type> | 
					
						
							|  |  |  |          ( &tree_type::container_from_iterator(it) | 
					
						
							|  |  |  |          , &avl_set_impl::tree_); | 
					
						
							|  |  |  |    } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Precondition</b>: it must be a valid const_iterator of set.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2008-04-27 15:03:06 +00:00
										 |  |  |    //! <b>Effects</b>: Returns a const reference to the set associated to the iterator
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2008-04-27 15:03:06 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2008-04-27 15:03:06 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							|  |  |  |    static const avl_set_impl &container_from_iterator(const_iterator it) | 
					
						
							|  |  |  |    { | 
					
						
							|  |  |  |       return *detail::parent_from_member<avl_set_impl, tree_type> | 
					
						
							|  |  |  |          ( &tree_type::container_from_iterator(it) | 
					
						
							|  |  |  |          , &avl_set_impl::tree_); | 
					
						
							|  |  |  |    } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Returns the key_compare object used by the avl_set.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If key_compare copy-constructor throws.
 | 
					
						
							|  |  |  |    key_compare key_comp() const | 
					
						
							|  |  |  |    { return tree_.value_comp(); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns the value_compare object used by the avl_set.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If value_compare copy-constructor throws.
 | 
					
						
							|  |  |  |    value_compare value_comp() const | 
					
						
							|  |  |  |    { return tree_.value_comp(); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns true is the container is empty.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    bool empty() const | 
					
						
							|  |  |  |    { return tree_.empty(); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns the number of elements stored in the avl_set.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Linear to elements contained in *this if,
 | 
					
						
							|  |  |  |    //!   constant-time size option is enabled. Constant-time otherwise.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    size_type size() const | 
					
						
							|  |  |  |    { return tree_.size(); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Swaps the contents of two sets.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the swap() call for the comparison functor
 | 
					
						
							|  |  |  |    //!   found using ADL throws. Strong guarantee.
 | 
					
						
							|  |  |  |    void swap(avl_set_impl& other) | 
					
						
							|  |  |  |    { tree_.swap(other.tree_); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: Disposer::operator()(pointer) shouldn't throw.
 | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  |    //!   Cloner should yield to nodes equivalent to the original nodes.
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Erases all the elements from *this
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!   calling Disposer::operator()(pointer), clones all the
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   elements from src calling Cloner::operator()(const_reference )
 | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  |    //!   and inserts them on *this. Copies the predicate from the source container.
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!
 | 
					
						
							|  |  |  |    //!   If cloner throws, all cloned elements are unlinked and disposed
 | 
					
						
							|  |  |  |    //!   calling Disposer::operator()(pointer).
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!  
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Linear to erased plus inserted elements.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  |    //! <b>Throws</b>: If cloner throws or predicate copy assignment throws. Basic guarantee.
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    template <class Cloner, class Disposer> | 
					
						
							|  |  |  |    void clone_from(const avl_set_impl &src, Cloner cloner, Disposer disposer) | 
					
						
							|  |  |  |    {  tree_.clone_from(src.tree_, cloner, disposer);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: value must be an lvalue
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2008-12-13 13:55:44 +00:00
										 |  |  |    //! <b>Effects</b>: Treaps to inserts value into the avl_set.
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Returns</b>: If the value
 | 
					
						
							|  |  |  |    //!   is not already present inserts it and returns a pair containing the
 | 
					
						
							|  |  |  |    //!   iterator to the new value and true. If there is an equivalent value
 | 
					
						
							|  |  |  |    //!   returns a pair containing an iterator to the already present value
 | 
					
						
							|  |  |  |    //!   and false.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Average complexity for insert element is at
 | 
					
						
							|  |  |  |    //!   most logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws. Strong guarantee.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Does not affect the validity of iterators and references.
 | 
					
						
							|  |  |  |    //!   No copy-constructors are called.
 | 
					
						
							|  |  |  |    std::pair<iterator, bool> insert(reference value) | 
					
						
							|  |  |  |    {  return tree_.insert_unique(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: value must be an lvalue
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Treaps to to insert x into the avl_set, using "hint"
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   as a hint to where it will be inserted.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Returns</b>: An iterator that points to the position where the
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   new element was inserted into the avl_set.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic in general, but it's amortized
 | 
					
						
							|  |  |  |    //!   constant time if t is inserted immediately before hint.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws. Strong guarantee.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Does not affect the validity of iterators and references.
 | 
					
						
							|  |  |  |    //!   No copy-constructors are called.
 | 
					
						
							|  |  |  |    iterator insert(const_iterator hint, reference value) | 
					
						
							|  |  |  |    {  return tree_.insert_unique(hint, value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Requires</b>: key_value_comp must be a comparison function that induces
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   the same strict weak ordering as value_compare. The difference is that
 | 
					
						
							| 
									
										
										
										
											2008-12-13 13:55:44 +00:00
										 |  |  |    //!   key_value_comp compares an arbitrary key with the contained values.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Checks if a value can be inserted in the avl_set, using
 | 
					
						
							|  |  |  |    //!   a user provided key instead of the value itself.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Returns</b>: If there is an equivalent value
 | 
					
						
							|  |  |  |    //!   returns a pair containing an iterator to the already present value
 | 
					
						
							|  |  |  |    //!   and false. If the value can be inserted returns true in the returned
 | 
					
						
							|  |  |  |    //!   pair boolean and fills "commit_data" that is meant to be used with
 | 
					
						
							|  |  |  |    //!   the "insert_commit" function.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Average complexity is at most logarithmic.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Throws</b>: If the key_value_comp ordering function throws. Strong guarantee.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Notes</b>: This function is used to improve performance when constructing
 | 
					
						
							|  |  |  |    //!   a value_type is expensive: if there is an equivalent value
 | 
					
						
							|  |  |  |    //!   the constructed object must be discarded. Many times, the part of the
 | 
					
						
							|  |  |  |    //!   node that is used to impose the order is much cheaper to construct
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!   than the value_type and this function offers the possibility to use that
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   part to check if the insertion will be successful.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //!   If the check is successful, the user can construct the value_type and use
 | 
					
						
							|  |  |  |    //!   "insert_commit" to insert the object in constant-time. This gives a total
 | 
					
						
							|  |  |  |    //!   logarithmic complexity to the insertion: check(O(log(N)) + commit(O(1)).
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //!   "commit_data" remains valid for a subsequent "insert_commit" only if no more
 | 
					
						
							|  |  |  |    //!   objects are inserted or erased from the avl_set.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare> | 
					
						
							|  |  |  |    std::pair<iterator, bool> insert_check | 
					
						
							|  |  |  |       (const KeyType &key, KeyValueCompare key_value_comp, insert_commit_data &commit_data) | 
					
						
							|  |  |  |    {  return tree_.insert_unique_check(key, key_value_comp, commit_data); } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Requires</b>: key_value_comp must be a comparison function that induces
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   the same strict weak ordering as value_compare. The difference is that
 | 
					
						
							| 
									
										
										
										
											2008-12-13 13:55:44 +00:00
										 |  |  |    //!   key_value_comp compares an arbitrary key with the contained values.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Checks if a value can be inserted in the avl_set, using
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!   a user provided key instead of the value itself, using "hint"
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   as a hint to where it will be inserted.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Returns</b>: If there is an equivalent value
 | 
					
						
							|  |  |  |    //!   returns a pair containing an iterator to the already present value
 | 
					
						
							|  |  |  |    //!   and false. If the value can be inserted returns true in the returned
 | 
					
						
							|  |  |  |    //!   pair boolean and fills "commit_data" that is meant to be used with
 | 
					
						
							|  |  |  |    //!   the "insert_commit" function.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic in general, but it's amortized
 | 
					
						
							|  |  |  |    //!   constant time if t is inserted immediately before hint.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Throws</b>: If the key_value_comp ordering function throws. Strong guarantee.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Notes</b>: This function is used to improve performance when constructing
 | 
					
						
							|  |  |  |    //!   a value_type is expensive: if there is an equivalent value
 | 
					
						
							|  |  |  |    //!   the constructed object must be discarded. Many times, the part of the
 | 
					
						
							|  |  |  |    //!   constructing that is used to impose the order is much cheaper to construct
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!   than the value_type and this function offers the possibility to use that key
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   to check if the insertion will be successful.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //!   If the check is successful, the user can construct the value_type and use
 | 
					
						
							|  |  |  |    //!   "insert_commit" to insert the object in constant-time. This can give a total
 | 
					
						
							|  |  |  |    //!   constant-time complexity to the insertion: check(O(1)) + commit(O(1)).
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!  
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   "commit_data" remains valid for a subsequent "insert_commit" only if no more
 | 
					
						
							|  |  |  |    //!   objects are inserted or erased from the avl_set.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare> | 
					
						
							|  |  |  |    std::pair<iterator, bool> insert_check | 
					
						
							|  |  |  |       (const_iterator hint, const KeyType &key | 
					
						
							|  |  |  |       ,KeyValueCompare key_value_comp, insert_commit_data &commit_data) | 
					
						
							|  |  |  |    {  return tree_.insert_unique_check(hint, key, key_value_comp, commit_data); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: value must be an lvalue of type value_type. commit_data
 | 
					
						
							|  |  |  |    //!   must have been obtained from a previous call to "insert_check".
 | 
					
						
							|  |  |  |    //!   No objects should have been inserted or erased from the avl_set between
 | 
					
						
							|  |  |  |    //!   the "insert_check" that filled "commit_data" and the call to "insert_commit".
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Inserts the value in the avl_set using the information obtained
 | 
					
						
							|  |  |  |    //!   from the "commit_data" that a previous "insert_check" filled.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Returns</b>: An iterator to the newly inserted object.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant time.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Notes</b>: This function has only sense if a "insert_check" has been
 | 
					
						
							|  |  |  |    //!   previously executed to fill "commit_data". No value should be inserted or
 | 
					
						
							|  |  |  |    //!   erased between the "insert_check" and "insert_commit" calls.
 | 
					
						
							|  |  |  |    iterator insert_commit(reference value, const insert_commit_data &commit_data) | 
					
						
							|  |  |  |    {  return tree_.insert_unique_commit(value, commit_data); } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Requires</b>: Dereferencing iterator must yield an lvalue
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   of type value_type.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Inserts a range into the avl_set.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Insert range is in general O(N * log(N)), where N is the
 | 
					
						
							|  |  |  |    //!   size of the range. However, it is linear in N if the range is already sorted
 | 
					
						
							|  |  |  |    //!   by value_comp().
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws. Basic guarantee.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Does not affect the validity of iterators and references.
 | 
					
						
							|  |  |  |    //!   No copy-constructors are called.
 | 
					
						
							|  |  |  |    template<class Iterator> | 
					
						
							|  |  |  |    void insert(Iterator b, Iterator e) | 
					
						
							|  |  |  |    {  tree_.insert_unique(b, e);  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-14 11:59:32 +00:00
										 |  |  |    //! <b>Requires</b>: value must be an lvalue, "pos" must be
 | 
					
						
							|  |  |  |    //!   a valid iterator (or end) and must be the succesor of value
 | 
					
						
							|  |  |  |    //!   once inserted according to the predicate. "value" must not be equal to any
 | 
					
						
							|  |  |  |    //!   inserted key according to the predicate.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Inserts x into the tree before "pos".
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2009-10-14 11:59:32 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant time.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2009-10-14 11:59:32 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2009-10-14 11:59:32 +00:00
										 |  |  |    //! <b>Note</b>: This function does not check preconditions so if "pos" is not
 | 
					
						
							|  |  |  |    //! the successor of "value" or "value" is not unique tree ordering and uniqueness
 | 
					
						
							|  |  |  |    //! invariants will be broken respectively.
 | 
					
						
							|  |  |  |    //! This is a low-level function to be used only for performance reasons
 | 
					
						
							|  |  |  |    //! by advanced users.
 | 
					
						
							|  |  |  |    iterator insert_before(const_iterator pos, reference value) | 
					
						
							|  |  |  |    {  return tree_.insert_before(pos, value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: value must be an lvalue, and it must be greater than
 | 
					
						
							|  |  |  |    //!   any inserted key according to the predicate.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Inserts x into the tree in the last position.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2009-10-14 11:59:32 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant time.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2009-10-14 11:59:32 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2009-10-14 11:59:32 +00:00
										 |  |  |    //! <b>Note</b>: This function does not check preconditions so if value is
 | 
					
						
							|  |  |  |    //!   less than or equal to the greatest inserted key tree ordering invariant will be broken.
 | 
					
						
							|  |  |  |    //!   This function is slightly more efficient than using "insert_before".
 | 
					
						
							|  |  |  |    //!   This is a low-level function to be used only for performance reasons
 | 
					
						
							|  |  |  |    //!   by advanced users.
 | 
					
						
							|  |  |  |    void push_back(reference value) | 
					
						
							|  |  |  |    {  tree_.push_back(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: value must be an lvalue, and it must be less
 | 
					
						
							|  |  |  |    //!   than any inserted key according to the predicate.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Inserts x into the tree in the first position.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2009-10-14 11:59:32 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant time.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2009-10-14 11:59:32 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2009-10-14 11:59:32 +00:00
										 |  |  |    //! <b>Note</b>: This function does not check preconditions so if value is
 | 
					
						
							|  |  |  |    //!   greater than or equal to the the mimum inserted key tree ordering or uniqueness
 | 
					
						
							|  |  |  |    //!   invariants will be broken.
 | 
					
						
							|  |  |  |    //!   This function is slightly more efficient than using "insert_before".
 | 
					
						
							|  |  |  |    //!   This is a low-level function to be used only for performance reasons
 | 
					
						
							|  |  |  |    //!   by advanced users.
 | 
					
						
							|  |  |  |    void push_front(reference value) | 
					
						
							|  |  |  |    {  tree_.push_front(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Effects</b>: Erases the element pointed to by pos.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Average complexity is constant time.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Returns</b>: An iterator to the element after the erased element.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Invalidates the iterators (but not the references)
 | 
					
						
							|  |  |  |    //!    to the erased elements. No destructors are called.
 | 
					
						
							| 
									
										
										
										
											2008-12-13 13:55:44 +00:00
										 |  |  |    iterator erase(const_iterator i) | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    {  return tree_.erase(i);  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Effects</b>: Erases the range pointed to by b end e.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Complexity</b>: Average complexity for erase range is at most
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   O(log(size() + N)), where N is the number of elements in the range.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Returns</b>: An iterator to the element after the erased elements.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Invalidates the iterators (but not the references)
 | 
					
						
							|  |  |  |    //!    to the erased elements. No destructors are called.
 | 
					
						
							| 
									
										
										
										
											2008-12-13 13:55:44 +00:00
										 |  |  |    iterator erase(const_iterator b, const_iterator e) | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    {  return tree_.erase(b, e);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Erases all the elements with the given value.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Returns</b>: The number of erased elements.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: O(log(size()) + this->count(value)).
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws. Basic guarantee.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Invalidates the iterators (but not the references)
 | 
					
						
							|  |  |  |    //!    to the erased elements. No destructors are called.
 | 
					
						
							|  |  |  |    size_type erase(const_reference value) | 
					
						
							|  |  |  |    {  return tree_.erase(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Erases all the elements that compare equal with
 | 
					
						
							|  |  |  |    //!   the given key and the given comparison functor.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Returns</b>: The number of erased elements.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: O(log(size() + this->count(key, comp)).
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the comp ordering function throws. Basic guarantee.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Invalidates the iterators (but not the references)
 | 
					
						
							|  |  |  |    //!    to the erased elements. No destructors are called.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare> | 
					
						
							| 
									
										
										
										
											2008-12-13 13:55:44 +00:00
										 |  |  |    size_type erase(const KeyType& key, KeyValueCompare comp | 
					
						
							|  |  |  |                   /// @cond
 | 
					
						
							|  |  |  |                   , typename detail::enable_if_c<!detail::is_convertible<KeyValueCompare, const_iterator>::value >::type * = 0 | 
					
						
							|  |  |  |                   /// @endcond
 | 
					
						
							|  |  |  |                   ) | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    {  return tree_.erase(key, comp);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: Disposer::operator()(pointer) shouldn't throw.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Effects</b>: Erases the element pointed to by pos.
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   Disposer::operator()(pointer) is called for the removed element.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Complexity</b>: Average complexity for erase element is constant time.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Returns</b>: An iterator to the element after the erased element.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Note</b>: Invalidates the iterators
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!    to the erased elements.
 | 
					
						
							|  |  |  |    template<class Disposer> | 
					
						
							| 
									
										
										
										
											2008-12-13 13:55:44 +00:00
										 |  |  |    iterator erase_and_dispose(const_iterator i, Disposer disposer) | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    {  return tree_.erase_and_dispose(i, disposer);  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-13 13:55:44 +00:00
										 |  |  |    #if !defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							|  |  |  |    template<class Disposer> | 
					
						
							|  |  |  |    iterator erase_and_dispose(iterator i, Disposer disposer) | 
					
						
							|  |  |  |    {  return this->erase_and_dispose(const_iterator(i), disposer);   } | 
					
						
							|  |  |  |    #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Requires</b>: Disposer::operator()(pointer) shouldn't throw.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Erases the range pointed to by b end e.
 | 
					
						
							|  |  |  |    //!   Disposer::operator()(pointer) is called for the removed elements.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Complexity</b>: Average complexity for erase range is at most
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   O(log(size() + N)), where N is the number of elements in the range.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Returns</b>: An iterator to the element after the erased elements.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Invalidates the iterators
 | 
					
						
							|  |  |  |    //!    to the erased elements.
 | 
					
						
							|  |  |  |    template<class Disposer> | 
					
						
							| 
									
										
										
										
											2008-12-13 13:55:44 +00:00
										 |  |  |    iterator erase_and_dispose(const_iterator b, const_iterator e, Disposer disposer) | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    {  return tree_.erase_and_dispose(b, e, disposer);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: Disposer::operator()(pointer) shouldn't throw.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Erases all the elements with the given value.
 | 
					
						
							|  |  |  |    //!   Disposer::operator()(pointer) is called for the removed elements.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: O(log(size() + this->count(value)). Basic guarantee.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Invalidates the iterators (but not the references)
 | 
					
						
							|  |  |  |    //!    to the erased elements. No destructors are called.
 | 
					
						
							|  |  |  |    template<class Disposer> | 
					
						
							|  |  |  |    size_type erase_and_dispose(const_reference value, Disposer disposer) | 
					
						
							|  |  |  |    {  return tree_.erase_and_dispose(value, disposer);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: Disposer::operator()(pointer) shouldn't throw.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Erases all the elements with the given key.
 | 
					
						
							|  |  |  |    //!   according to the comparison functor "comp".
 | 
					
						
							|  |  |  |    //!   Disposer::operator()(pointer) is called for the removed elements.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Returns</b>: The number of erased elements.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: O(log(size() + this->count(key, comp)).
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If comp ordering function throws. Basic guarantee.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Invalidates the iterators
 | 
					
						
							|  |  |  |    //!    to the erased elements.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare, class Disposer> | 
					
						
							| 
									
										
										
										
											2008-12-13 13:55:44 +00:00
										 |  |  |    size_type erase_and_dispose(const KeyType& key, KeyValueCompare comp, Disposer disposer | 
					
						
							|  |  |  |                   /// @cond
 | 
					
						
							|  |  |  |                   , typename detail::enable_if_c<!detail::is_convertible<KeyValueCompare, const_iterator>::value >::type * = 0 | 
					
						
							|  |  |  |                   /// @endcond
 | 
					
						
							|  |  |  |                   ) | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    {  return tree_.erase_and_dispose(key, comp, disposer);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Erases all the elements of the container.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Linear to the number of elements on the container.
 | 
					
						
							|  |  |  |    //!   if it's a safe-mode or auto-unlink value_type. Constant time otherwise.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Invalidates the iterators (but not the references)
 | 
					
						
							|  |  |  |    //!    to the erased elements. No destructors are called.
 | 
					
						
							|  |  |  |    void clear() | 
					
						
							|  |  |  |    {  return tree_.clear();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: Disposer::operator()(pointer) shouldn't throw.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Erases all the elements of the container.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Linear to the number of elements on the container.
 | 
					
						
							|  |  |  |    //!   Disposer::operator()(pointer) is called for the removed elements.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Invalidates the iterators (but not the references)
 | 
					
						
							|  |  |  |    //!    to the erased elements. No destructors are called.
 | 
					
						
							|  |  |  |    template<class Disposer> | 
					
						
							|  |  |  |    void clear_and_dispose(Disposer disposer) | 
					
						
							|  |  |  |    {  return tree_.clear_and_dispose(disposer);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns the number of contained elements with the given key
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic to the number of elements contained plus lineal
 | 
					
						
							|  |  |  |    //!   to number of objects with the given key.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws.
 | 
					
						
							|  |  |  |    size_type count(const_reference value) const | 
					
						
							|  |  |  |    {  return tree_.find(value) != end();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns the number of contained elements with the same key
 | 
					
						
							|  |  |  |    //!   compared with the given comparison functor.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic to the number of elements contained plus lineal
 | 
					
						
							|  |  |  |    //!   to number of objects with the given key.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If comp ordering function throws.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare> | 
					
						
							|  |  |  |    size_type count(const KeyType& key, KeyValueCompare comp) const | 
					
						
							|  |  |  |    {  return tree_.find(key, comp) != end();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns an iterator to the first element whose
 | 
					
						
							|  |  |  |    //!   key is not less than k or end() if that element does not exist.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws.
 | 
					
						
							|  |  |  |    iterator lower_bound(const_reference value) | 
					
						
							|  |  |  |    {  return tree_.lower_bound(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: comp must imply the same element order as
 | 
					
						
							|  |  |  |    //!   value_compare. Usually key is the part of the value_type
 | 
					
						
							|  |  |  |    //!   that is used in the ordering functor.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns an iterator to the first element whose
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!   key according to the comparison functor is not less than k or
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   end() if that element does not exist.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If comp ordering function throws.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: This function is used when constructing a value_type
 | 
					
						
							|  |  |  |    //!   is expensive and the value_type can be compared with a cheaper
 | 
					
						
							|  |  |  |    //!   key type. Usually this key is part of the value_type.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare> | 
					
						
							|  |  |  |    iterator lower_bound(const KeyType& key, KeyValueCompare comp) | 
					
						
							|  |  |  |    {  return tree_.lower_bound(key, comp);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a const iterator to the first element whose
 | 
					
						
							|  |  |  |    //!   key is not less than k or end() if that element does not exist.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws.
 | 
					
						
							|  |  |  |    const_iterator lower_bound(const_reference value) const | 
					
						
							|  |  |  |    {  return tree_.lower_bound(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: comp must imply the same element order as
 | 
					
						
							|  |  |  |    //!   value_compare. Usually key is the part of the value_type
 | 
					
						
							|  |  |  |    //!   that is used in the ordering functor.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a const_iterator to the first element whose
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!   key according to the comparison functor is not less than k or
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   end() if that element does not exist.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If comp ordering function throws.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: This function is used when constructing a value_type
 | 
					
						
							|  |  |  |    //!   is expensive and the value_type can be compared with a cheaper
 | 
					
						
							|  |  |  |    //!   key type. Usually this key is part of the value_type.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare> | 
					
						
							|  |  |  |    const_iterator lower_bound(const KeyType& key, KeyValueCompare comp) const | 
					
						
							|  |  |  |    {  return tree_.lower_bound(key, comp);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns an iterator to the first element whose
 | 
					
						
							|  |  |  |    //!   key is greater than k or end() if that element does not exist.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws.
 | 
					
						
							|  |  |  |    iterator upper_bound(const_reference value) | 
					
						
							|  |  |  |    {  return tree_.upper_bound(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: comp must imply the same element order as
 | 
					
						
							|  |  |  |    //!   value_compare. Usually key is the part of the value_type
 | 
					
						
							|  |  |  |    //!   that is used in the ordering functor.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns an iterator to the first element whose
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!   key according to the comparison functor is greater than key or
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   end() if that element does not exist.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If comp ordering function throws.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Note</b>: This function is used when constructing a value_type
 | 
					
						
							|  |  |  |    //!   is expensive and the value_type can be compared with a cheaper
 | 
					
						
							|  |  |  |    //!   key type. Usually this key is part of the value_type.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare> | 
					
						
							|  |  |  |    iterator upper_bound(const KeyType& key, KeyValueCompare comp) | 
					
						
							|  |  |  |    {  return tree_.upper_bound(key, comp);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns an iterator to the first element whose
 | 
					
						
							|  |  |  |    //!   key is greater than k or end() if that element does not exist.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws.
 | 
					
						
							|  |  |  |    const_iterator upper_bound(const_reference value) const | 
					
						
							|  |  |  |    {  return tree_.upper_bound(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: comp must imply the same element order as
 | 
					
						
							|  |  |  |    //!   value_compare. Usually key is the part of the value_type
 | 
					
						
							|  |  |  |    //!   that is used in the ordering functor.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a const_iterator to the first element whose
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!   key according to the comparison functor is greater than key or
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   end() if that element does not exist.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If comp ordering function throws.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Note</b>: This function is used when constructing a value_type
 | 
					
						
							|  |  |  |    //!   is expensive and the value_type can be compared with a cheaper
 | 
					
						
							|  |  |  |    //!   key type. Usually this key is part of the value_type.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare> | 
					
						
							|  |  |  |    const_iterator upper_bound(const KeyType& key, KeyValueCompare comp) const | 
					
						
							|  |  |  |    {  return tree_.upper_bound(key, comp);  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Effects</b>: Finds an iterator to the first element whose value is
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   "value" or end() if that element does not exist.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws.
 | 
					
						
							|  |  |  |    iterator find(const_reference value) | 
					
						
							|  |  |  |    {  return tree_.find(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: comp must imply the same element order as
 | 
					
						
							|  |  |  |    //!   value_compare. Usually key is the part of the value_type
 | 
					
						
							|  |  |  |    //!   that is used in the ordering functor.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Effects</b>: Finds an iterator to the first element whose key is
 | 
					
						
							|  |  |  |    //!   "key" according to the comparison functor or end() if that element
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   does not exist.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If comp ordering function throws.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Note</b>: This function is used when constructing a value_type
 | 
					
						
							|  |  |  |    //!   is expensive and the value_type can be compared with a cheaper
 | 
					
						
							|  |  |  |    //!   key type. Usually this key is part of the value_type.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare> | 
					
						
							|  |  |  |    iterator find(const KeyType& key, KeyValueCompare comp) | 
					
						
							|  |  |  |    {  return tree_.find(key, comp);  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Effects</b>: Finds a const_iterator to the first element whose value is
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   "value" or end() if that element does not exist.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws.
 | 
					
						
							|  |  |  |    const_iterator find(const_reference value) const | 
					
						
							|  |  |  |    {  return tree_.find(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: comp must imply the same element order as
 | 
					
						
							|  |  |  |    //!   value_compare. Usually key is the part of the value_type
 | 
					
						
							|  |  |  |    //!   that is used in the ordering functor.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Effects</b>: Finds a const_iterator to the first element whose key is
 | 
					
						
							|  |  |  |    //!   "key" according to the comparison functor or end() if that element
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   does not exist.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If comp ordering function throws.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Note</b>: This function is used when constructing a value_type
 | 
					
						
							|  |  |  |    //!   is expensive and the value_type can be compared with a cheaper
 | 
					
						
							|  |  |  |    //!   key type. Usually this key is part of the value_type.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare> | 
					
						
							|  |  |  |    const_iterator find(const KeyType& key, KeyValueCompare comp) const | 
					
						
							|  |  |  |    {  return tree_.find(key, comp);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Finds a range containing all elements whose key is k or
 | 
					
						
							|  |  |  |    //!   an empty range that indicates the position where those elements would be
 | 
					
						
							|  |  |  |    //!   if they there is no elements with key k.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws.
 | 
					
						
							|  |  |  |    std::pair<iterator,iterator> equal_range(const_reference value) | 
					
						
							|  |  |  |    {  return tree_.equal_range(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: comp must imply the same element order as
 | 
					
						
							|  |  |  |    //!   value_compare. Usually key is the part of the value_type
 | 
					
						
							|  |  |  |    //!   that is used in the ordering functor.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Effects</b>: Finds a range containing all elements whose key is k
 | 
					
						
							|  |  |  |    //!   according to the comparison functor or an empty range
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   that indicates the position where those elements would be
 | 
					
						
							|  |  |  |    //!   if they there is no elements with key k.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If comp ordering function throws.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Note</b>: This function is used when constructing a value_type
 | 
					
						
							|  |  |  |    //!   is expensive and the value_type can be compared with a cheaper
 | 
					
						
							|  |  |  |    //!   key type. Usually this key is part of the value_type.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare> | 
					
						
							|  |  |  |    std::pair<iterator,iterator> equal_range(const KeyType& key, KeyValueCompare comp) | 
					
						
							|  |  |  |    {  return tree_.equal_range(key, comp);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Finds a range containing all elements whose key is k or
 | 
					
						
							|  |  |  |    //!   an empty range that indicates the position where those elements would be
 | 
					
						
							|  |  |  |    //!   if they there is no elements with key k.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws.
 | 
					
						
							|  |  |  |    std::pair<const_iterator, const_iterator> | 
					
						
							|  |  |  |       equal_range(const_reference value) const | 
					
						
							|  |  |  |    {  return tree_.equal_range(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: comp must imply the same element order as
 | 
					
						
							|  |  |  |    //!   value_compare. Usually key is the part of the value_type
 | 
					
						
							|  |  |  |    //!   that is used in the ordering functor.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Effects</b>: Finds a range containing all elements whose key is k
 | 
					
						
							|  |  |  |    //!   according to the comparison functor or an empty range
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   that indicates the position where those elements would be
 | 
					
						
							|  |  |  |    //!   if they there is no elements with key k.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If comp ordering function throws.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Note</b>: This function is used when constructing a value_type
 | 
					
						
							|  |  |  |    //!   is expensive and the value_type can be compared with a cheaper
 | 
					
						
							|  |  |  |    //!   key type. Usually this key is part of the value_type.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare> | 
					
						
							|  |  |  |    std::pair<const_iterator, const_iterator> | 
					
						
							|  |  |  |       equal_range(const KeyType& key, KeyValueCompare comp) const | 
					
						
							|  |  |  |    {  return tree_.equal_range(key, comp);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: value must be an lvalue and shall be in a avl_set of
 | 
					
						
							|  |  |  |    //!   appropriate type. Otherwise the behavior is undefined.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Returns: a valid iterator i belonging to the avl_set
 | 
					
						
							|  |  |  |    //!   that points to the value
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: This static function is available only if the <i>value traits</i>
 | 
					
						
							|  |  |  |    //!   is stateless.
 | 
					
						
							|  |  |  |    static iterator s_iterator_to(reference value) | 
					
						
							|  |  |  |    {  return tree_type::s_iterator_to(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: value must be an lvalue and shall be in a avl_set of
 | 
					
						
							|  |  |  |    //!   appropriate type. Otherwise the behavior is undefined.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Returns: a valid const_iterator i belonging to the
 | 
					
						
							|  |  |  |    //!   avl_set that points to the value
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: This static function is available only if the <i>value traits</i>
 | 
					
						
							|  |  |  |    //!   is stateless.
 | 
					
						
							|  |  |  |    static const_iterator s_iterator_to(const_reference value) | 
					
						
							|  |  |  |    {  return tree_type::s_iterator_to(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: value must be an lvalue and shall be in a avl_set of
 | 
					
						
							|  |  |  |    //!   appropriate type. Otherwise the behavior is undefined.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Returns: a valid iterator i belonging to the avl_set
 | 
					
						
							|  |  |  |    //!   that points to the value
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    iterator iterator_to(reference value) | 
					
						
							|  |  |  |    {  return tree_.iterator_to(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: value must be an lvalue and shall be in a avl_set of
 | 
					
						
							|  |  |  |    //!   appropriate type. Otherwise the behavior is undefined.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Returns: a valid const_iterator i belonging to the
 | 
					
						
							|  |  |  |    //!   avl_set that points to the value
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    const_iterator iterator_to(const_reference value) const | 
					
						
							|  |  |  |    {  return tree_.iterator_to(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: value shall not be in a avl_set/avl_multiset.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: init_node puts the hook of a value in a well-known default
 | 
					
						
							|  |  |  |    //!   state.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant time.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: This function puts the hook in the well-known default state
 | 
					
						
							|  |  |  |    //!   used by auto_unlink and safe hooks.
 | 
					
						
							|  |  |  |    static void init_node(reference value) | 
					
						
							|  |  |  |    { tree_type::init_node(value);   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Unlinks the leftmost node from the tree.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Average complexity is constant time.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Notes</b>: This function breaks the tree and the tree can
 | 
					
						
							|  |  |  |    //!   only be used for more unlink_leftmost_without_rebalance calls.
 | 
					
						
							|  |  |  |    //!   This function is normally used to achieve a step by step
 | 
					
						
							|  |  |  |    //!   controlled destruction of the tree.
 | 
					
						
							|  |  |  |    pointer unlink_leftmost_without_rebalance() | 
					
						
							|  |  |  |    {  return tree_.unlink_leftmost_without_rebalance();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: replace_this must be a valid iterator of *this
 | 
					
						
							|  |  |  |    //!   and with_this must not be inserted in any tree.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Replaces replace_this in its position in the
 | 
					
						
							|  |  |  |    //!   tree with with_this. The tree does not need to be rebalanced.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: This function will break container ordering invariants if
 | 
					
						
							|  |  |  |    //!   with_this is not equivalent to *replace_this according to the
 | 
					
						
							|  |  |  |    //!   ordering rules. This function is faster than erasing and inserting
 | 
					
						
							|  |  |  |    //!   the node, since no rebalancing or comparison is needed.
 | 
					
						
							|  |  |  |    void replace_node(iterator replace_this, reference with_this) | 
					
						
							|  |  |  |    {  tree_.replace_node(replace_this, with_this);   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    /// @cond
 | 
					
						
							|  |  |  |    friend bool operator==(const avl_set_impl &x, const avl_set_impl &y) | 
					
						
							|  |  |  |    {  return x.tree_ == y.tree_;  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    friend bool operator<(const avl_set_impl &x, const avl_set_impl &y) | 
					
						
							|  |  |  |    {  return x.tree_ < y.tree_;  } | 
					
						
							|  |  |  |    /// @endcond
 | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | template<class T, class ...Options> | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | template<class Config> | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | inline bool operator!= | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | (const avl_set_impl<T, Options...> &x, const avl_set_impl<T, Options...> &y) | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | (const avl_set_impl<Config> &x, const avl_set_impl<Config> &y) | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | {  return !(x == y); } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | template<class T, class ...Options> | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | template<class Config> | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | inline bool operator> | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | (const avl_set_impl<T, Options...> &x, const avl_set_impl<T, Options...> &y) | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | (const avl_set_impl<Config> &x, const avl_set_impl<Config> &y) | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | {  return y < x;  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | template<class T, class ...Options> | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | template<class Config> | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | inline bool operator<= | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | (const avl_set_impl<T, Options...> &x, const avl_set_impl<T, Options...> &y) | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | (const avl_set_impl<Config> &x, const avl_set_impl<Config> &y) | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | {  return !(y < x);  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | template<class T, class ...Options> | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | template<class Config> | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | inline bool operator>= | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | (const avl_set_impl<T, Options...> &x, const avl_set_impl<T, Options...> &y) | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | (const avl_set_impl<Config> &x, const avl_set_impl<Config> &y) | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | {  return !(x < y);  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | template<class T, class ...Options> | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | template<class Config> | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | inline void swap | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | (avl_set_impl<T, Options...> &x, avl_set_impl<T, Options...> &y) | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | (avl_set_impl<Config> &x, avl_set_impl<Config> &y) | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | {  x.swap(y);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //! Helper metafunction to define a \c avl_set that yields to the same type when the
 | 
					
						
							|  |  |  | //! same options (either explicitly or implicitly) are used.
 | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED) || defined(BOOST_INTRUSIVE_VARIADIC_TEMPLATES)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | template<class T, class ...Options> | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | template<class T, class O1 = none, class O2 = none | 
					
						
							|  |  |  |                 , class O3 = none, class O4 = none> | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | struct make_avl_set | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |    /// @cond
 | 
					
						
							|  |  |  |    typedef avl_set_impl | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  |       < typename make_avltree_opt | 
					
						
							|  |  |  |       #if !defined(BOOST_INTRUSIVE_VARIADIC_TEMPLATES)
 | 
					
						
							|  |  |  |       <T, O1, O2, O3, O4> | 
					
						
							|  |  |  |       #else
 | 
					
						
							|  |  |  |       <T, Options...> | 
					
						
							|  |  |  |       #endif
 | 
					
						
							|  |  |  |       ::type | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |       > implementation_defined; | 
					
						
							|  |  |  |    /// @endcond
 | 
					
						
							|  |  |  |    typedef implementation_defined type; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef BOOST_INTRUSIVE_DOXYGEN_INVOKED
 | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #if !defined(BOOST_INTRUSIVE_VARIADIC_TEMPLATES)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | template<class T, class O1, class O2, class O3, class O4> | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | template<class T, class ...Options> | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | class avl_set | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  |    :  public make_avl_set | 
					
						
							|  |  |  |       #if !defined(BOOST_INTRUSIVE_VARIADIC_TEMPLATES)
 | 
					
						
							|  |  |  |       <T, O1, O2, O3, O4> | 
					
						
							|  |  |  |       #else
 | 
					
						
							|  |  |  |       <T, Options...> | 
					
						
							|  |  |  |       #endif
 | 
					
						
							|  |  |  |       ::type | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | { | 
					
						
							|  |  |  |    typedef typename make_avl_set | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  |       #if !defined(BOOST_INTRUSIVE_VARIADIC_TEMPLATES)
 | 
					
						
							|  |  |  |       <T, O1, O2, O3, O4> | 
					
						
							|  |  |  |       #else
 | 
					
						
							|  |  |  |       <T, Options...> | 
					
						
							|  |  |  |       #endif
 | 
					
						
							|  |  |  |       ::type   Base; | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-21 08:58:28 +00:00
										 |  |  |    BOOST_MOVABLE_BUT_NOT_COPYABLE(avl_set) | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    public: | 
					
						
							|  |  |  |    typedef typename Base::value_compare      value_compare; | 
					
						
							|  |  |  |    typedef typename Base::value_traits       value_traits; | 
					
						
							|  |  |  |    typedef typename Base::iterator           iterator; | 
					
						
							|  |  |  |    typedef typename Base::const_iterator     const_iterator; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //Assert if passed value traits are compatible with the type
 | 
					
						
							|  |  |  |    BOOST_STATIC_ASSERT((detail::is_same<typename value_traits::value_type, T>::value)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    avl_set( const value_compare &cmp = value_compare() | 
					
						
							|  |  |  |          , const value_traits &v_traits = value_traits()) | 
					
						
							|  |  |  |       :  Base(cmp, v_traits) | 
					
						
							|  |  |  |    {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    template<class Iterator> | 
					
						
							|  |  |  |    avl_set( Iterator b, Iterator e | 
					
						
							|  |  |  |       , const value_compare &cmp = value_compare() | 
					
						
							|  |  |  |       , const value_traits &v_traits = value_traits()) | 
					
						
							|  |  |  |       :  Base(b, e, cmp, v_traits) | 
					
						
							|  |  |  |    {} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-21 08:58:28 +00:00
										 |  |  |    avl_set(BOOST_RV_REF(avl_set) x) | 
					
						
							|  |  |  |       :  Base(::boost::move(static_cast<Base&>(x))) | 
					
						
							|  |  |  |    {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    avl_set& operator=(BOOST_RV_REF(avl_set) x) | 
					
						
							|  |  |  |    {  this->Base::operator=(::boost::move(static_cast<Base&>(x))); return *this;  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    static avl_set &container_from_end_iterator(iterator end_iterator) | 
					
						
							|  |  |  |    {  return static_cast<avl_set &>(Base::container_from_end_iterator(end_iterator));   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    static const avl_set &container_from_end_iterator(const_iterator end_iterator) | 
					
						
							|  |  |  |    {  return static_cast<const avl_set &>(Base::container_from_end_iterator(end_iterator));   } | 
					
						
							| 
									
										
										
										
											2008-04-27 15:03:06 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    static avl_set &container_from_iterator(iterator end_iterator) | 
					
						
							|  |  |  |    {  return static_cast<avl_set &>(Base::container_from_iterator(end_iterator));   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    static const avl_set &container_from_iterator(const_iterator end_iterator) | 
					
						
							|  |  |  |    {  return static_cast<const avl_set &>(Base::container_from_iterator(end_iterator));   } | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  | //! The class template avl_multiset is an intrusive container, that mimics most of
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | //! the interface of std::avl_multiset as described in the C++ standard.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  | //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | //! The template parameter \c T is the type to be managed by the container.
 | 
					
						
							|  |  |  | //! The user can specify additional options and if no options are provided
 | 
					
						
							|  |  |  | //! default options are used.
 | 
					
						
							|  |  |  | //!
 | 
					
						
							|  |  |  | //! The container supports the following options:
 | 
					
						
							|  |  |  | //! \c base_hook<>/member_hook<>/value_traits<>,
 | 
					
						
							|  |  |  | //! \c constant_time_size<>, \c size_type<> and
 | 
					
						
							|  |  |  | //! \c compare<>.
 | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | template<class T, class ...Options> | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | template<class Config> | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | class avl_multiset_impl | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |    /// @cond
 | 
					
						
							|  |  |  |    typedef avltree_impl<Config> tree_type; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-21 08:58:28 +00:00
										 |  |  |    //Movable
 | 
					
						
							|  |  |  |    BOOST_MOVABLE_BUT_NOT_COPYABLE(avl_multiset_impl) | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    typedef tree_type implementation_defined; | 
					
						
							|  |  |  |    /// @endcond
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    public: | 
					
						
							|  |  |  |    typedef typename implementation_defined::value_type               value_type; | 
					
						
							|  |  |  |    typedef typename implementation_defined::value_traits             value_traits; | 
					
						
							|  |  |  |    typedef typename implementation_defined::pointer                  pointer; | 
					
						
							|  |  |  |    typedef typename implementation_defined::const_pointer            const_pointer; | 
					
						
							|  |  |  |    typedef typename implementation_defined::reference                reference; | 
					
						
							|  |  |  |    typedef typename implementation_defined::const_reference          const_reference; | 
					
						
							|  |  |  |    typedef typename implementation_defined::difference_type          difference_type; | 
					
						
							|  |  |  |    typedef typename implementation_defined::size_type                size_type; | 
					
						
							|  |  |  |    typedef typename implementation_defined::value_compare            value_compare; | 
					
						
							|  |  |  |    typedef typename implementation_defined::key_compare              key_compare; | 
					
						
							|  |  |  |    typedef typename implementation_defined::iterator                 iterator; | 
					
						
							|  |  |  |    typedef typename implementation_defined::const_iterator           const_iterator; | 
					
						
							|  |  |  |    typedef typename implementation_defined::reverse_iterator         reverse_iterator; | 
					
						
							|  |  |  |    typedef typename implementation_defined::const_reverse_iterator   const_reverse_iterator; | 
					
						
							|  |  |  |    typedef typename implementation_defined::insert_commit_data       insert_commit_data; | 
					
						
							|  |  |  |    typedef typename implementation_defined::node_traits              node_traits; | 
					
						
							|  |  |  |    typedef typename implementation_defined::node                     node; | 
					
						
							|  |  |  |    typedef typename implementation_defined::node_ptr                 node_ptr; | 
					
						
							|  |  |  |    typedef typename implementation_defined::const_node_ptr           const_node_ptr; | 
					
						
							|  |  |  |    typedef typename implementation_defined::node_algorithms          node_algorithms; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
											
												Interprocess:
  [@https://svn.boost.org/trac/boost/ticket/3439 #3439],
  [@https://svn.boost.org/trac/boost/ticket/3846 #3846],
  [@https://svn.boost.org/trac/boost/ticket/3947 #3947],
  [@https://svn.boost.org/trac/boost/ticket/3985 #3985].
Intrusive:
  [@https://svn.boost.org/trac/boost/ticket/3668 #3668],
  [@https://svn.boost.org/trac/boost/ticket/3339 #3688],
  [@https://svn.boost.org/trac/boost/ticket/3698 #3698],
  [@https://svn.boost.org/trac/boost/ticket/3706 #3706],
  [@https://svn.boost.org/trac/boost/ticket/3721 #3721].
  [@https://svn.boost.org/trac/boost/ticket/3729 #3729],
  [@https://svn.boost.org/trac/boost/ticket/3746 #3746],
  [@https://svn.boost.org/trac/boost/ticket/3781 #3781],
  [@https://svn.boost.org/trac/boost/ticket/3829 #3829],
  [@https://svn.boost.org/trac/boost/ticket/3840 #3840],
  [@https://svn.boost.org/trac/boost/ticket/3339 #3339],
  [@https://svn.boost.org/trac/boost/ticket/3419 #3419],
  [@https://svn.boost.org/trac/boost/ticket/3431 #3431],
[SVN r60514]
											
										 
											2010-03-12 13:18:29 +00:00
										 |  |  |    static const bool constant_time_size = Config::constant_time_size; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    /// @cond
 | 
					
						
							|  |  |  |    private: | 
					
						
							|  |  |  |    tree_type tree_; | 
					
						
							|  |  |  |    /// @endcond
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    public: | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Effects</b>: Constructs an empty avl_multiset.
 | 
					
						
							|  |  |  |    //!  
 | 
					
						
							|  |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If value_traits::node_traits::node
 | 
					
						
							|  |  |  |    //!   constructor throws (this does not happen with predefined Boost.Intrusive hooks)
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!   or the copy constructor/operator() of the value_compare object throws.
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    avl_multiset_impl( const value_compare &cmp = value_compare() | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |                 , const value_traits &v_traits = value_traits()) | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |       :  tree_(cmp, v_traits) | 
					
						
							|  |  |  |    {} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Requires</b>: Dereferencing iterator must yield an lvalue of type value_type.
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   cmp must be a comparison function that induces a strict weak ordering.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Constructs an empty avl_multiset and inserts elements from
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   [b, e).
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Linear in N if [b, e) is already sorted using
 | 
					
						
							|  |  |  |    //!   comp and otherwise N * log N, where N is the distance between first and last
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If value_traits::node_traits::node
 | 
					
						
							|  |  |  |    //!   constructor throws (this does not happen with predefined Boost.Intrusive hooks)
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!   or the copy constructor/operator() of the value_compare object throws.
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    template<class Iterator> | 
					
						
							|  |  |  |    avl_multiset_impl( Iterator b, Iterator e | 
					
						
							|  |  |  |                 , const value_compare &cmp = value_compare() | 
					
						
							|  |  |  |                 , const value_traits &v_traits = value_traits()) | 
					
						
							|  |  |  |       : tree_(false, b, e, cmp, v_traits) | 
					
						
							|  |  |  |    {} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-21 08:58:28 +00:00
										 |  |  |    //! <b>Effects</b>: to-do
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!  
 | 
					
						
							|  |  |  |    avl_multiset_impl(BOOST_RV_REF(avl_multiset_impl) x) | 
					
						
							| 
									
										
										
										
											2011-03-21 08:58:28 +00:00
										 |  |  |       :  tree_(::boost::move(x.tree_)) | 
					
						
							|  |  |  |    {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: to-do
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!  
 | 
					
						
							|  |  |  |    avl_multiset_impl& operator=(BOOST_RV_REF(avl_multiset_impl) x) | 
					
						
							| 
									
										
										
										
											2011-03-21 08:58:28 +00:00
										 |  |  |    {  tree_ = ::boost::move(x.tree_);  return *this;  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Effects</b>: Detaches all elements from this. The objects in the avl_multiset
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   are not deleted (i.e. no destructors are called).
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-11-18 10:43:35 +00:00
										 |  |  |    //! <b>Complexity</b>: Linear to the number of elements on the container.
 | 
					
						
							|  |  |  |    //!   if it's a safe-mode or auto-unlink value_type. Constant time otherwise.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    ~avl_multiset_impl() | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns an iterator pointing to the beginning of the avl_multiset.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    iterator begin() | 
					
						
							|  |  |  |    { return tree_.begin();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a const_iterator pointing to the beginning of the avl_multiset.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    const_iterator begin() const | 
					
						
							|  |  |  |    { return tree_.begin();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a const_iterator pointing to the beginning of the avl_multiset.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    const_iterator cbegin() const | 
					
						
							|  |  |  |    { return tree_.cbegin();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns an iterator pointing to the end of the avl_multiset.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    iterator end() | 
					
						
							|  |  |  |    { return tree_.end();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a const_iterator pointing to the end of the avl_multiset.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    const_iterator end() const | 
					
						
							|  |  |  |    { return tree_.end();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a const_iterator pointing to the end of the avl_multiset.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    const_iterator cend() const | 
					
						
							|  |  |  |    { return tree_.cend();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a reverse_iterator pointing to the beginning of the
 | 
					
						
							|  |  |  |    //!    reversed avl_multiset.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    reverse_iterator rbegin() | 
					
						
							|  |  |  |    { return tree_.rbegin();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a const_reverse_iterator pointing to the beginning
 | 
					
						
							|  |  |  |    //!    of the reversed avl_multiset.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    const_reverse_iterator rbegin() const | 
					
						
							|  |  |  |    { return tree_.rbegin();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a const_reverse_iterator pointing to the beginning
 | 
					
						
							|  |  |  |    //!    of the reversed avl_multiset.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    const_reverse_iterator crbegin() const | 
					
						
							|  |  |  |    { return tree_.crbegin();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a reverse_iterator pointing to the end
 | 
					
						
							|  |  |  |    //!    of the reversed avl_multiset.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    reverse_iterator rend() | 
					
						
							|  |  |  |    { return tree_.rend();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a const_reverse_iterator pointing to the end
 | 
					
						
							|  |  |  |    //!    of the reversed avl_multiset.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    const_reverse_iterator rend() const | 
					
						
							|  |  |  |    { return tree_.rend();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a const_reverse_iterator pointing to the end
 | 
					
						
							|  |  |  |    //!    of the reversed avl_multiset.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    const_reverse_iterator crend() const | 
					
						
							|  |  |  |    { return tree_.crend();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Precondition</b>: end_iterator must be a valid end iterator
 | 
					
						
							|  |  |  |    //!   of avl_multiset.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Returns a const reference to the avl_multiset associated to the end iterator
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							|  |  |  |    static avl_multiset_impl &container_from_end_iterator(iterator end_iterator) | 
					
						
							|  |  |  |    { | 
					
						
							|  |  |  |       return *detail::parent_from_member<avl_multiset_impl, tree_type> | 
					
						
							|  |  |  |          ( &tree_type::container_from_end_iterator(end_iterator) | 
					
						
							|  |  |  |          , &avl_multiset_impl::tree_); | 
					
						
							|  |  |  |    } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Precondition</b>: end_iterator must be a valid end const_iterator
 | 
					
						
							|  |  |  |    //!   of avl_multiset.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Returns a const reference to the avl_multiset associated to the end iterator
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							|  |  |  |    static const avl_multiset_impl &container_from_end_iterator(const_iterator end_iterator) | 
					
						
							|  |  |  |    { | 
					
						
							|  |  |  |       return *detail::parent_from_member<avl_multiset_impl, tree_type> | 
					
						
							|  |  |  |          ( &tree_type::container_from_end_iterator(end_iterator) | 
					
						
							|  |  |  |          , &avl_multiset_impl::tree_); | 
					
						
							|  |  |  |    } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-27 15:03:06 +00:00
										 |  |  |    //! <b>Precondition</b>: it must be a valid iterator of multiset.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2008-04-27 15:03:06 +00:00
										 |  |  |    //! <b>Effects</b>: Returns a const reference to the multiset associated to the iterator
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2008-04-27 15:03:06 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2008-04-27 15:03:06 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							|  |  |  |    static avl_multiset_impl &container_from_iterator(iterator it) | 
					
						
							|  |  |  |    { | 
					
						
							|  |  |  |       return *detail::parent_from_member<avl_multiset_impl, tree_type> | 
					
						
							|  |  |  |          ( &tree_type::container_from_iterator(it) | 
					
						
							|  |  |  |          , &avl_multiset_impl::tree_); | 
					
						
							|  |  |  |    } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Precondition</b>: it must be a valid const_iterator of multiset.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2008-04-27 15:03:06 +00:00
										 |  |  |    //! <b>Effects</b>: Returns a const reference to the multiset associated to the iterator
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2008-04-27 15:03:06 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2008-04-27 15:03:06 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							|  |  |  |    static const avl_multiset_impl &container_from_iterator(const_iterator it) | 
					
						
							|  |  |  |    { | 
					
						
							|  |  |  |       return *detail::parent_from_member<avl_multiset_impl, tree_type> | 
					
						
							|  |  |  |          ( &tree_type::container_from_iterator(it) | 
					
						
							|  |  |  |          , &avl_multiset_impl::tree_); | 
					
						
							|  |  |  |    } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Returns the key_compare object used by the avl_multiset.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If key_compare copy-constructor throws.
 | 
					
						
							|  |  |  |    key_compare key_comp() const | 
					
						
							|  |  |  |    { return tree_.value_comp(); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns the value_compare object used by the avl_multiset.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If value_compare copy-constructor throws.
 | 
					
						
							|  |  |  |    value_compare value_comp() const | 
					
						
							|  |  |  |    { return tree_.value_comp(); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns true is the container is empty.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    bool empty() const | 
					
						
							|  |  |  |    { return tree_.empty(); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns the number of elements stored in the avl_multiset.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Linear to elements contained in *this if,
 | 
					
						
							|  |  |  |    //!   constant-time size option is enabled. Constant-time otherwise.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    size_type size() const | 
					
						
							|  |  |  |    { return tree_.size(); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Swaps the contents of two avl_multisets.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the swap() call for the comparison functor
 | 
					
						
							|  |  |  |    //!   found using ADL throws. Strong guarantee.
 | 
					
						
							|  |  |  |    void swap(avl_multiset_impl& other) | 
					
						
							|  |  |  |    { tree_.swap(other.tree_); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: Disposer::operator()(pointer) shouldn't throw.
 | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  |    //!   Cloner should yield to nodes equivalent to the original nodes.
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Erases all the elements from *this
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!   calling Disposer::operator()(pointer), clones all the
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   elements from src calling Cloner::operator()(const_reference )
 | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  |    //!   and inserts them on *this. Copies the predicate from the source container.
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!
 | 
					
						
							|  |  |  |    //!   If cloner throws, all cloned elements are unlinked and disposed
 | 
					
						
							|  |  |  |    //!   calling Disposer::operator()(pointer).
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!  
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Linear to erased plus inserted elements.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  |    //! <b>Throws</b>: If cloner throws or predicate copy assignment throws. Basic guarantee.
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    template <class Cloner, class Disposer> | 
					
						
							|  |  |  |    void clone_from(const avl_multiset_impl &src, Cloner cloner, Disposer disposer) | 
					
						
							|  |  |  |    {  tree_.clone_from(src.tree_, cloner, disposer);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: value must be an lvalue
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Inserts value into the avl_multiset.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Returns</b>: An iterator that points to the position where the new
 | 
					
						
							|  |  |  |    //!   element was inserted.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Average complexity for insert element is at
 | 
					
						
							|  |  |  |    //!   most logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws. Strong guarantee.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Does not affect the validity of iterators and references.
 | 
					
						
							|  |  |  |    //!   No copy-constructors are called.
 | 
					
						
							|  |  |  |    iterator insert(reference value) | 
					
						
							|  |  |  |    {  return tree_.insert_equal(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: value must be an lvalue
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Inserts x into the avl_multiset, using pos as a hint to
 | 
					
						
							|  |  |  |    //!   where it will be inserted.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Returns</b>: An iterator that points to the position where the new
 | 
					
						
							|  |  |  |    //!   element was inserted.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic in general, but it is amortized
 | 
					
						
							|  |  |  |    //!   constant time if t is inserted immediately before hint.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws. Strong guarantee.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Does not affect the validity of iterators and references.
 | 
					
						
							|  |  |  |    //!   No copy-constructors are called.
 | 
					
						
							|  |  |  |    iterator insert(const_iterator hint, reference value) | 
					
						
							|  |  |  |    {  return tree_.insert_equal(hint, value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Requires</b>: Dereferencing iterator must yield an lvalue
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   of type value_type.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Inserts a range into the avl_multiset.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Returns</b>: An iterator that points to the position where the new
 | 
					
						
							|  |  |  |    //!   element was inserted.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Insert range is in general O(N * log(N)), where N is the
 | 
					
						
							|  |  |  |    //!   size of the range. However, it is linear in N if the range is already sorted
 | 
					
						
							|  |  |  |    //!   by value_comp().
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws. Basic guarantee.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Does not affect the validity of iterators and references.
 | 
					
						
							|  |  |  |    //!   No copy-constructors are called.
 | 
					
						
							|  |  |  |    template<class Iterator> | 
					
						
							|  |  |  |    void insert(Iterator b, Iterator e) | 
					
						
							|  |  |  |    {  tree_.insert_equal(b, e);  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-14 11:59:32 +00:00
										 |  |  |    //! <b>Requires</b>: value must be an lvalue, "pos" must be
 | 
					
						
							|  |  |  |    //!   a valid iterator (or end) and must be the succesor of value
 | 
					
						
							|  |  |  |    //!   once inserted according to the predicate. "value" must not be equal to any
 | 
					
						
							|  |  |  |    //!   inserted key according to the predicate.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Inserts x into the tree before "pos".
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2009-10-14 11:59:32 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant time.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2009-10-14 11:59:32 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2009-10-14 11:59:32 +00:00
										 |  |  |    //! <b>Note</b>: This function does not check preconditions so if "pos" is not
 | 
					
						
							|  |  |  |    //! the successor of "value" or "value" is not unique tree ordering and uniqueness
 | 
					
						
							|  |  |  |    //! invariants will be broken respectively.
 | 
					
						
							|  |  |  |    //! This is a low-level function to be used only for performance reasons
 | 
					
						
							|  |  |  |    //! by advanced users.
 | 
					
						
							|  |  |  |    iterator insert_before(const_iterator pos, reference value) | 
					
						
							|  |  |  |    {  return tree_.insert_before(pos, value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: value must be an lvalue, and it must be greater than
 | 
					
						
							|  |  |  |    //!   any inserted key according to the predicate.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Inserts x into the tree in the last position.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2009-10-14 11:59:32 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant time.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2009-10-14 11:59:32 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2009-10-14 11:59:32 +00:00
										 |  |  |    //! <b>Note</b>: This function does not check preconditions so if value is
 | 
					
						
							|  |  |  |    //!   less than or equal to the greatest inserted key tree ordering invariant will be broken.
 | 
					
						
							|  |  |  |    //!   This function is slightly more efficient than using "insert_before".
 | 
					
						
							|  |  |  |    //!   This is a low-level function to be used only for performance reasons
 | 
					
						
							|  |  |  |    //!   by advanced users.
 | 
					
						
							|  |  |  |    void push_back(reference value) | 
					
						
							|  |  |  |    {  tree_.push_back(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: value must be an lvalue, and it must be less
 | 
					
						
							|  |  |  |    //!   than any inserted key according to the predicate.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Inserts x into the tree in the first position.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2009-10-14 11:59:32 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant time.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2009-10-14 11:59:32 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2009-10-14 11:59:32 +00:00
										 |  |  |    //! <b>Note</b>: This function does not check preconditions so if value is
 | 
					
						
							|  |  |  |    //!   greater than or equal to the the mimum inserted key tree ordering or uniqueness
 | 
					
						
							|  |  |  |    //!   invariants will be broken.
 | 
					
						
							|  |  |  |    //!   This function is slightly more efficient than using "insert_before".
 | 
					
						
							|  |  |  |    //!   This is a low-level function to be used only for performance reasons
 | 
					
						
							|  |  |  |    //!   by advanced users.
 | 
					
						
							|  |  |  |    void push_front(reference value) | 
					
						
							|  |  |  |    {  tree_.push_front(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Effects</b>: Erases the element pointed to by pos.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2009-10-14 11:59:32 +00:00
										 |  |  |    //! <b>Complexity</b>: Average complexity is constant time.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Returns</b>: An iterator to the element after the erased element.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Invalidates the iterators (but not the references)
 | 
					
						
							|  |  |  |    //!    to the erased elements. No destructors are called.
 | 
					
						
							| 
									
										
										
										
											2008-12-13 13:55:44 +00:00
										 |  |  |    iterator erase(const_iterator i) | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    {  return tree_.erase(i);  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Effects</b>: Erases the range pointed to by b end e.
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Returns</b>: An iterator to the element after the erased elements.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Complexity</b>: Average complexity for erase range is at most
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   O(log(size() + N)), where N is the number of elements in the range.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Invalidates the iterators (but not the references)
 | 
					
						
							|  |  |  |    //!    to the erased elements. No destructors are called.
 | 
					
						
							| 
									
										
										
										
											2008-12-13 13:55:44 +00:00
										 |  |  |    iterator erase(const_iterator b, const_iterator e) | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    {  return tree_.erase(b, e);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Erases all the elements with the given value.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Returns</b>: The number of erased elements.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: O(log(size() + this->count(value)).
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws. Basic guarantee.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Invalidates the iterators (but not the references)
 | 
					
						
							|  |  |  |    //!    to the erased elements. No destructors are called.
 | 
					
						
							|  |  |  |    size_type erase(const_reference value) | 
					
						
							|  |  |  |    {  return tree_.erase(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Erases all the elements that compare equal with
 | 
					
						
							|  |  |  |    //!   the given key and the given comparison functor.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Returns</b>: The number of erased elements.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: O(log(size() + this->count(key, comp)).
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If comp ordering function throws. Basic guarantee.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Invalidates the iterators (but not the references)
 | 
					
						
							|  |  |  |    //!    to the erased elements. No destructors are called.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare> | 
					
						
							| 
									
										
										
										
											2008-12-13 13:55:44 +00:00
										 |  |  |    size_type erase(const KeyType& key, KeyValueCompare comp | 
					
						
							|  |  |  |                   /// @cond
 | 
					
						
							|  |  |  |                   , typename detail::enable_if_c<!detail::is_convertible<KeyValueCompare, const_iterator>::value >::type * = 0 | 
					
						
							|  |  |  |                   /// @endcond
 | 
					
						
							|  |  |  |                   ) | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    {  return tree_.erase(key, comp);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: Disposer::operator()(pointer) shouldn't throw.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Returns</b>: An iterator to the element after the erased element.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Effects</b>: Erases the element pointed to by pos.
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   Disposer::operator()(pointer) is called for the removed element.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Complexity</b>: Average complexity for erase element is constant time.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Note</b>: Invalidates the iterators
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!    to the erased elements.
 | 
					
						
							|  |  |  |    template<class Disposer> | 
					
						
							| 
									
										
										
										
											2008-12-13 13:55:44 +00:00
										 |  |  |    iterator erase_and_dispose(const_iterator i, Disposer disposer) | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    {  return tree_.erase_and_dispose(i, disposer);  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-13 13:55:44 +00:00
										 |  |  |    #if !defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							|  |  |  |    template<class Disposer> | 
					
						
							|  |  |  |    iterator erase_and_dispose(iterator i, Disposer disposer) | 
					
						
							|  |  |  |    {  return this->erase_and_dispose(const_iterator(i), disposer);   } | 
					
						
							|  |  |  |    #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Requires</b>: Disposer::operator()(pointer) shouldn't throw.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Returns</b>: An iterator to the element after the erased elements.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Erases the range pointed to by b end e.
 | 
					
						
							|  |  |  |    //!   Disposer::operator()(pointer) is called for the removed elements.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Complexity</b>: Average complexity for erase range is at most
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   O(log(size() + N)), where N is the number of elements in the range.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Invalidates the iterators
 | 
					
						
							|  |  |  |    //!    to the erased elements.
 | 
					
						
							|  |  |  |    template<class Disposer> | 
					
						
							| 
									
										
										
										
											2008-12-13 13:55:44 +00:00
										 |  |  |    iterator erase_and_dispose(const_iterator b, const_iterator e, Disposer disposer) | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    {  return tree_.erase_and_dispose(b, e, disposer);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: Disposer::operator()(pointer) shouldn't throw.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Erases all the elements with the given value.
 | 
					
						
							|  |  |  |    //!   Disposer::operator()(pointer) is called for the removed elements.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Returns</b>: The number of erased elements.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: O(log(size() + this->count(value)).
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws. Basic guarantee.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Invalidates the iterators (but not the references)
 | 
					
						
							|  |  |  |    //!    to the erased elements. No destructors are called.
 | 
					
						
							|  |  |  |    template<class Disposer> | 
					
						
							|  |  |  |    size_type erase_and_dispose(const_reference value, Disposer disposer) | 
					
						
							|  |  |  |    {  return tree_.erase_and_dispose(value, disposer);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: Disposer::operator()(pointer) shouldn't throw.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Erases all the elements with the given key.
 | 
					
						
							|  |  |  |    //!   according to the comparison functor "comp".
 | 
					
						
							|  |  |  |    //!   Disposer::operator()(pointer) is called for the removed elements.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Returns</b>: The number of erased elements.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: O(log(size() + this->count(key, comp)).
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If comp ordering function throws. Basic guarantee.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Invalidates the iterators
 | 
					
						
							|  |  |  |    //!    to the erased elements.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare, class Disposer> | 
					
						
							| 
									
										
										
										
											2008-12-13 13:55:44 +00:00
										 |  |  |    size_type erase_and_dispose(const KeyType& key, KeyValueCompare comp, Disposer disposer | 
					
						
							|  |  |  |                   /// @cond
 | 
					
						
							|  |  |  |                   , typename detail::enable_if_c<!detail::is_convertible<KeyValueCompare, const_iterator>::value >::type * = 0 | 
					
						
							|  |  |  |                   /// @endcond
 | 
					
						
							|  |  |  |                   ) | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    {  return tree_.erase_and_dispose(key, comp, disposer);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Erases all the elements of the container.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Linear to the number of elements on the container.
 | 
					
						
							|  |  |  |    //!   if it's a safe-mode or auto-unlink value_type. Constant time otherwise.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Invalidates the iterators (but not the references)
 | 
					
						
							|  |  |  |    //!    to the erased elements. No destructors are called.
 | 
					
						
							|  |  |  |    void clear() | 
					
						
							|  |  |  |    {  return tree_.clear();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: Disposer::operator()(pointer) shouldn't throw.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Erases all the elements of the container.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Linear to the number of elements on the container.
 | 
					
						
							|  |  |  |    //!   Disposer::operator()(pointer) is called for the removed elements.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: Invalidates the iterators (but not the references)
 | 
					
						
							|  |  |  |    //!    to the erased elements. No destructors are called.
 | 
					
						
							|  |  |  |    template<class Disposer> | 
					
						
							|  |  |  |    void clear_and_dispose(Disposer disposer) | 
					
						
							|  |  |  |    {  return tree_.clear_and_dispose(disposer);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns the number of contained elements with the given key
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic to the number of elements contained plus lineal
 | 
					
						
							|  |  |  |    //!   to number of objects with the given key.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws.
 | 
					
						
							|  |  |  |    size_type count(const_reference value) const | 
					
						
							|  |  |  |    {  return tree_.count(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns the number of contained elements with the same key
 | 
					
						
							|  |  |  |    //!   compared with the given comparison functor.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic to the number of elements contained plus lineal
 | 
					
						
							|  |  |  |    //!   to number of objects with the given key.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If comp ordering function throws.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare> | 
					
						
							|  |  |  |    size_type count(const KeyType& key, KeyValueCompare comp) const | 
					
						
							|  |  |  |    {  return tree_.count(key, comp);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns an iterator to the first element whose
 | 
					
						
							|  |  |  |    //!   key is not less than k or end() if that element does not exist.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws.
 | 
					
						
							|  |  |  |    iterator lower_bound(const_reference value) | 
					
						
							|  |  |  |    {  return tree_.lower_bound(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: comp must imply the same element order as
 | 
					
						
							|  |  |  |    //!   value_compare. Usually key is the part of the value_type
 | 
					
						
							|  |  |  |    //!   that is used in the ordering functor.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns an iterator to the first element whose
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!   key according to the comparison functor is not less than k or
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   end() if that element does not exist.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If comp ordering function throws.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: This function is used when constructing a value_type
 | 
					
						
							|  |  |  |    //!   is expensive and the value_type can be compared with a cheaper
 | 
					
						
							|  |  |  |    //!   key type. Usually this key is part of the value_type.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare> | 
					
						
							|  |  |  |    iterator lower_bound(const KeyType& key, KeyValueCompare comp) | 
					
						
							|  |  |  |    {  return tree_.lower_bound(key, comp);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a const iterator to the first element whose
 | 
					
						
							|  |  |  |    //!   key is not less than k or end() if that element does not exist.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws.
 | 
					
						
							|  |  |  |    const_iterator lower_bound(const_reference value) const | 
					
						
							|  |  |  |    {  return tree_.lower_bound(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: comp must imply the same element order as
 | 
					
						
							|  |  |  |    //!   value_compare. Usually key is the part of the value_type
 | 
					
						
							|  |  |  |    //!   that is used in the ordering functor.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a const_iterator to the first element whose
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!   key according to the comparison functor is not less than k or
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   end() if that element does not exist.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If comp ordering function throws.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: This function is used when constructing a value_type
 | 
					
						
							|  |  |  |    //!   is expensive and the value_type can be compared with a cheaper
 | 
					
						
							|  |  |  |    //!   key type. Usually this key is part of the value_type.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare> | 
					
						
							|  |  |  |    const_iterator lower_bound(const KeyType& key, KeyValueCompare comp) const | 
					
						
							|  |  |  |    {  return tree_.lower_bound(key, comp);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns an iterator to the first element whose
 | 
					
						
							|  |  |  |    //!   key is greater than k or end() if that element does not exist.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws.
 | 
					
						
							|  |  |  |    iterator upper_bound(const_reference value) | 
					
						
							|  |  |  |    {  return tree_.upper_bound(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: comp must imply the same element order as
 | 
					
						
							|  |  |  |    //!   value_compare. Usually key is the part of the value_type
 | 
					
						
							|  |  |  |    //!   that is used in the ordering functor.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns an iterator to the first element whose
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!   key according to the comparison functor is greater than key or
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   end() if that element does not exist.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If comp ordering function throws.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Note</b>: This function is used when constructing a value_type
 | 
					
						
							|  |  |  |    //!   is expensive and the value_type can be compared with a cheaper
 | 
					
						
							|  |  |  |    //!   key type. Usually this key is part of the value_type.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare> | 
					
						
							|  |  |  |    iterator upper_bound(const KeyType& key, KeyValueCompare comp) | 
					
						
							|  |  |  |    {  return tree_.upper_bound(key, comp);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns an iterator to the first element whose
 | 
					
						
							|  |  |  |    //!   key is greater than k or end() if that element does not exist.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws.
 | 
					
						
							|  |  |  |    const_iterator upper_bound(const_reference value) const | 
					
						
							|  |  |  |    {  return tree_.upper_bound(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: comp must imply the same element order as
 | 
					
						
							|  |  |  |    //!   value_compare. Usually key is the part of the value_type
 | 
					
						
							|  |  |  |    //!   that is used in the ordering functor.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Returns a const_iterator to the first element whose
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!   key according to the comparison functor is greater than key or
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   end() if that element does not exist.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If comp ordering function throws.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Note</b>: This function is used when constructing a value_type
 | 
					
						
							|  |  |  |    //!   is expensive and the value_type can be compared with a cheaper
 | 
					
						
							|  |  |  |    //!   key type. Usually this key is part of the value_type.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare> | 
					
						
							|  |  |  |    const_iterator upper_bound(const KeyType& key, KeyValueCompare comp) const | 
					
						
							|  |  |  |    {  return tree_.upper_bound(key, comp);  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Effects</b>: Finds an iterator to the first element whose value is
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   "value" or end() if that element does not exist.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws.
 | 
					
						
							|  |  |  |    iterator find(const_reference value) | 
					
						
							|  |  |  |    {  return tree_.find(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: comp must imply the same element order as
 | 
					
						
							|  |  |  |    //!   value_compare. Usually key is the part of the value_type
 | 
					
						
							|  |  |  |    //!   that is used in the ordering functor.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Effects</b>: Finds an iterator to the first element whose key is
 | 
					
						
							|  |  |  |    //!   "key" according to the comparison functor or end() if that element
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   does not exist.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If comp ordering function throws.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Note</b>: This function is used when constructing a value_type
 | 
					
						
							|  |  |  |    //!   is expensive and the value_type can be compared with a cheaper
 | 
					
						
							|  |  |  |    //!   key type. Usually this key is part of the value_type.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare> | 
					
						
							|  |  |  |    iterator find(const KeyType& key, KeyValueCompare comp) | 
					
						
							|  |  |  |    {  return tree_.find(key, comp);  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Effects</b>: Finds a const_iterator to the first element whose value is
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   "value" or end() if that element does not exist.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws.
 | 
					
						
							|  |  |  |    const_iterator find(const_reference value) const | 
					
						
							|  |  |  |    {  return tree_.find(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: comp must imply the same element order as
 | 
					
						
							|  |  |  |    //!   value_compare. Usually key is the part of the value_type
 | 
					
						
							|  |  |  |    //!   that is used in the ordering functor.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Effects</b>: Finds a const_iterator to the first element whose key is
 | 
					
						
							|  |  |  |    //!   "key" according to the comparison functor or end() if that element
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   does not exist.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If comp ordering function throws.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Note</b>: This function is used when constructing a value_type
 | 
					
						
							|  |  |  |    //!   is expensive and the value_type can be compared with a cheaper
 | 
					
						
							|  |  |  |    //!   key type. Usually this key is part of the value_type.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare> | 
					
						
							|  |  |  |    const_iterator find(const KeyType& key, KeyValueCompare comp) const | 
					
						
							|  |  |  |    {  return tree_.find(key, comp);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Finds a range containing all elements whose key is k or
 | 
					
						
							|  |  |  |    //!   an empty range that indicates the position where those elements would be
 | 
					
						
							|  |  |  |    //!   if they there is no elements with key k.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws.
 | 
					
						
							|  |  |  |    std::pair<iterator,iterator> equal_range(const_reference value) | 
					
						
							|  |  |  |    {  return tree_.equal_range(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: comp must imply the same element order as
 | 
					
						
							|  |  |  |    //!   value_compare. Usually key is the part of the value_type
 | 
					
						
							|  |  |  |    //!   that is used in the ordering functor.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Effects</b>: Finds a range containing all elements whose key is k
 | 
					
						
							|  |  |  |    //!   according to the comparison functor or an empty range
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   that indicates the position where those elements would be
 | 
					
						
							|  |  |  |    //!   if they there is no elements with key k.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If comp ordering function throws.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Note</b>: This function is used when constructing a value_type
 | 
					
						
							|  |  |  |    //!   is expensive and the value_type can be compared with a cheaper
 | 
					
						
							|  |  |  |    //!   key type. Usually this key is part of the value_type.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare> | 
					
						
							|  |  |  |    std::pair<iterator,iterator> equal_range(const KeyType& key, KeyValueCompare comp) | 
					
						
							|  |  |  |    {  return tree_.equal_range(key, comp);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Finds a range containing all elements whose key is k or
 | 
					
						
							|  |  |  |    //!   an empty range that indicates the position where those elements would be
 | 
					
						
							|  |  |  |    //!   if they there is no elements with key k.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If the internal value_compare ordering function throws.
 | 
					
						
							|  |  |  |    std::pair<const_iterator, const_iterator> | 
					
						
							|  |  |  |       equal_range(const_reference value) const | 
					
						
							|  |  |  |    {  return tree_.equal_range(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: comp must imply the same element order as
 | 
					
						
							|  |  |  |    //!   value_compare. Usually key is the part of the value_type
 | 
					
						
							|  |  |  |    //!   that is used in the ordering functor.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //! <b>Effects</b>: Finds a range containing all elements whose key is k
 | 
					
						
							|  |  |  |    //!   according to the comparison functor or an empty range
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //!   that indicates the position where those elements would be
 | 
					
						
							|  |  |  |    //!   if they there is no elements with key k.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Logarithmic.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: If comp ordering function throws.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Note</b>: This function is used when constructing a value_type
 | 
					
						
							|  |  |  |    //!   is expensive and the value_type can be compared with a cheaper
 | 
					
						
							|  |  |  |    //!   key type. Usually this key is part of the value_type.
 | 
					
						
							|  |  |  |    template<class KeyType, class KeyValueCompare> | 
					
						
							|  |  |  |    std::pair<const_iterator, const_iterator> | 
					
						
							|  |  |  |       equal_range(const KeyType& key, KeyValueCompare comp) const | 
					
						
							|  |  |  |    {  return tree_.equal_range(key, comp);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: value must be an lvalue and shall be in a avl_multiset of
 | 
					
						
							|  |  |  |    //!   appropriate type. Otherwise the behavior is undefined.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Returns: a valid iterator i belonging to the avl_multiset
 | 
					
						
							|  |  |  |    //!   that points to the value
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: This static function is available only if the <i>value traits</i>
 | 
					
						
							|  |  |  |    //!   is stateless.
 | 
					
						
							|  |  |  |    static iterator s_iterator_to(reference value) | 
					
						
							|  |  |  |    {  return tree_type::s_iterator_to(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: value must be an lvalue and shall be in a avl_multiset of
 | 
					
						
							|  |  |  |    //!   appropriate type. Otherwise the behavior is undefined.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Returns: a valid const_iterator i belonging to the
 | 
					
						
							|  |  |  |    //!   avl_multiset that points to the value
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: This static function is available only if the <i>value traits</i>
 | 
					
						
							|  |  |  |    //!   is stateless.
 | 
					
						
							|  |  |  |    static const_iterator s_iterator_to(const_reference value) | 
					
						
							|  |  |  |    {  return tree_type::s_iterator_to(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: value must be an lvalue and shall be in a avl_multiset of
 | 
					
						
							|  |  |  |    //!   appropriate type. Otherwise the behavior is undefined.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Returns: a valid iterator i belonging to the avl_multiset
 | 
					
						
							|  |  |  |    //!   that points to the value
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    iterator iterator_to(reference value) | 
					
						
							|  |  |  |    {  return tree_.iterator_to(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: value must be an lvalue and shall be in a avl_multiset of
 | 
					
						
							|  |  |  |    //!   appropriate type. Otherwise the behavior is undefined.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Returns: a valid const_iterator i belonging to the
 | 
					
						
							|  |  |  |    //!   avl_multiset that points to the value
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							|  |  |  |    const_iterator iterator_to(const_reference value) const | 
					
						
							|  |  |  |    {  return tree_.iterator_to(value);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: value shall not be in a avl_multiset/avl_multiset.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: init_node puts the hook of a value in a well-known default
 | 
					
						
							|  |  |  |    //!   state.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Constant time.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: This function puts the hook in the well-known default state
 | 
					
						
							|  |  |  |    //!   used by auto_unlink and safe hooks.
 | 
					
						
							|  |  |  |    static void init_node(reference value) | 
					
						
							|  |  |  |    { tree_type::init_node(value);   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Effects</b>: Unlinks the leftmost node from the tree.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Complexity</b>: Average complexity is constant time.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Notes</b>: This function breaks the tree and the tree can
 | 
					
						
							|  |  |  |    //!   only be used for more unlink_leftmost_without_rebalance calls.
 | 
					
						
							|  |  |  |    //!   This function is normally used to achieve a step by step
 | 
					
						
							|  |  |  |    //!   controlled destruction of the tree.
 | 
					
						
							|  |  |  |    pointer unlink_leftmost_without_rebalance() | 
					
						
							|  |  |  |    {  return tree_.unlink_leftmost_without_rebalance();  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //! <b>Requires</b>: replace_this must be a valid iterator of *this
 | 
					
						
							|  |  |  |    //!   and with_this must not be inserted in any tree.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Effects</b>: Replaces replace_this in its position in the
 | 
					
						
							|  |  |  |    //!   tree with with_this. The tree does not need to be rebalanced.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							|  |  |  |    //! <b>Complexity</b>: Constant.
 | 
					
						
							|  |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Throws</b>: Nothing.
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    //!
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    //! <b>Note</b>: This function will break container ordering invariants if
 | 
					
						
							|  |  |  |    //!   with_this is not equivalent to *replace_this according to the
 | 
					
						
							|  |  |  |    //!   ordering rules. This function is faster than erasing and inserting
 | 
					
						
							|  |  |  |    //!   the node, since no rebalancing or comparison is needed.
 | 
					
						
							|  |  |  |    void replace_node(iterator replace_this, reference with_this) | 
					
						
							|  |  |  |    {  tree_.replace_node(replace_this, with_this);   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    /// @cond
 | 
					
						
							|  |  |  |    friend bool operator==(const avl_multiset_impl &x, const avl_multiset_impl &y) | 
					
						
							|  |  |  |    {  return x.tree_ == y.tree_;  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    friend bool operator<(const avl_multiset_impl &x, const avl_multiset_impl &y) | 
					
						
							|  |  |  |    {  return x.tree_ < y.tree_;  } | 
					
						
							|  |  |  |    /// @endcond
 | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | template<class T, class ...Options> | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | template<class Config> | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | inline bool operator!= | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | (const avl_multiset_impl<T, Options...> &x, const avl_multiset_impl<T, Options...> &y) | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | (const avl_multiset_impl<Config> &x, const avl_multiset_impl<Config> &y) | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | {  return !(x == y); } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | template<class T, class ...Options> | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | template<class Config> | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | inline bool operator> | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | (const avl_multiset_impl<T, Options...> &x, const avl_multiset_impl<T, Options...> &y) | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | (const avl_multiset_impl<Config> &x, const avl_multiset_impl<Config> &y) | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | {  return y < x;  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | template<class T, class ...Options> | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | template<class Config> | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | inline bool operator<= | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | (const avl_multiset_impl<T, Options...> &x, const avl_multiset_impl<T, Options...> &y) | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | (const avl_multiset_impl<Config> &x, const avl_multiset_impl<Config> &y) | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | {  return !(y < x);  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | template<class T, class ...Options> | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | template<class Config> | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | inline bool operator>= | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | (const avl_multiset_impl<T, Options...> &x, const avl_multiset_impl<T, Options...> &y) | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | (const avl_multiset_impl<Config> &x, const avl_multiset_impl<Config> &y) | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | {  return !(x < y);  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | template<class T, class ...Options> | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | template<class Config> | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | inline void swap | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | (avl_multiset_impl<T, Options...> &x, avl_multiset_impl<T, Options...> &y) | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | (avl_multiset_impl<Config> &x, avl_multiset_impl<Config> &y) | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | {  x.swap(y);  } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //! Helper metafunction to define a \c avl_multiset that yields to the same type when the
 | 
					
						
							|  |  |  | //! same options (either explicitly or implicitly) are used.
 | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #if defined(BOOST_INTRUSIVE_DOXYGEN_INVOKED) || defined(BOOST_INTRUSIVE_VARIADIC_TEMPLATES)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | template<class T, class ...Options> | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | template<class T, class O1 = none, class O2 = none | 
					
						
							|  |  |  |                 , class O3 = none, class O4 = none> | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | struct make_avl_multiset | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |    /// @cond
 | 
					
						
							|  |  |  |    typedef avl_multiset_impl | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  |       < typename make_avltree_opt | 
					
						
							|  |  |  |          #if !defined(BOOST_INTRUSIVE_VARIADIC_TEMPLATES)
 | 
					
						
							|  |  |  |          <T, O1, O2, O3, O4> | 
					
						
							|  |  |  |          #else
 | 
					
						
							|  |  |  |          <T, Options...> | 
					
						
							|  |  |  |          #endif
 | 
					
						
							|  |  |  |          ::type | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |       > implementation_defined; | 
					
						
							|  |  |  |    /// @endcond
 | 
					
						
							|  |  |  |    typedef implementation_defined type; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef BOOST_INTRUSIVE_DOXYGEN_INVOKED
 | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #if !defined(BOOST_INTRUSIVE_VARIADIC_TEMPLATES)
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | template<class T, class O1, class O2, class O3, class O4> | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | template<class T, class ...Options> | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | class avl_multiset | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  |    :  public make_avl_multiset<T, | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  |    #if !defined(BOOST_INTRUSIVE_VARIADIC_TEMPLATES)
 | 
					
						
							|  |  |  |    O1, O2, O3, O4 | 
					
						
							|  |  |  |    #else
 | 
					
						
							|  |  |  |    Options... | 
					
						
							|  |  |  |    #endif
 | 
					
						
							|  |  |  |    >::type | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | { | 
					
						
							|  |  |  |    typedef typename make_avl_multiset | 
					
						
							| 
									
										
										
										
											2008-10-11 13:14:49 +00:00
										 |  |  |       #if !defined(BOOST_INTRUSIVE_VARIADIC_TEMPLATES)
 | 
					
						
							|  |  |  |       <T, O1, O2, O3, O4> | 
					
						
							|  |  |  |       #else
 | 
					
						
							|  |  |  |       <T, Options...> | 
					
						
							|  |  |  |       #endif
 | 
					
						
							|  |  |  |       ::type   Base; | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-21 08:58:28 +00:00
										 |  |  |    BOOST_MOVABLE_BUT_NOT_COPYABLE(avl_multiset) | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    public: | 
					
						
							|  |  |  |    typedef typename Base::value_compare      value_compare; | 
					
						
							|  |  |  |    typedef typename Base::value_traits       value_traits; | 
					
						
							|  |  |  |    typedef typename Base::iterator           iterator; | 
					
						
							|  |  |  |    typedef typename Base::const_iterator     const_iterator; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    //Assert if passed value traits are compatible with the type
 | 
					
						
							|  |  |  |    BOOST_STATIC_ASSERT((detail::is_same<typename value_traits::value_type, T>::value)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    avl_multiset( const value_compare &cmp = value_compare() | 
					
						
							|  |  |  |            , const value_traits &v_traits = value_traits()) | 
					
						
							|  |  |  |       :  Base(cmp, v_traits) | 
					
						
							|  |  |  |    {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    template<class Iterator> | 
					
						
							|  |  |  |    avl_multiset( Iterator b, Iterator e | 
					
						
							|  |  |  |            , const value_compare &cmp = value_compare() | 
					
						
							|  |  |  |            , const value_traits &v_traits = value_traits()) | 
					
						
							|  |  |  |       :  Base(b, e, cmp, v_traits) | 
					
						
							|  |  |  |    {} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-21 08:58:28 +00:00
										 |  |  |    avl_multiset(BOOST_RV_REF(avl_multiset) x) | 
					
						
							|  |  |  |       :  Base(::boost::move(static_cast<Base&>(x))) | 
					
						
							|  |  |  |    {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    avl_multiset& operator=(BOOST_RV_REF(avl_multiset) x) | 
					
						
							|  |  |  |    {  this->Base::operator=(::boost::move(static_cast<Base&>(x))); return *this;  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  |    static avl_multiset &container_from_end_iterator(iterator end_iterator) | 
					
						
							|  |  |  |    {  return static_cast<avl_multiset &>(Base::container_from_end_iterator(end_iterator));   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    static const avl_multiset &container_from_end_iterator(const_iterator end_iterator) | 
					
						
							|  |  |  |    {  return static_cast<const avl_multiset &>(Base::container_from_end_iterator(end_iterator));   } | 
					
						
							| 
									
										
										
										
											2008-04-27 15:03:06 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |    static avl_multiset &container_from_iterator(iterator end_iterator) | 
					
						
							|  |  |  |    {  return static_cast<avl_multiset &>(Base::container_from_iterator(end_iterator));   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    static const avl_multiset &container_from_iterator(const_iterator end_iterator) | 
					
						
							|  |  |  |    {  return static_cast<const avl_multiset &>(Base::container_from_iterator(end_iterator));   } | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-20 09:57:59 +00:00
										 |  |  | } //namespace intrusive
 | 
					
						
							|  |  |  | } //namespace boost
 | 
					
						
							| 
									
										
										
										
											2007-10-30 07:00:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include <boost/intrusive/detail/config_end.hpp>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif //BOOST_INTRUSIVE_AVL_SET_HPP
 |