29 #ifndef _GLIBCXX_DEBUG_MULTISET_H 
   30 #define _GLIBCXX_DEBUG_MULTISET_H 1 
   36 namespace std _GLIBCXX_VISIBILITY(default)
 
   41   template<
typename _Key, 
typename _Compare = std::less<_Key>,
 
   42        typename _Allocator = std::allocator<_Key> >
 
   44     : 
public _GLIBCXX_STD_C::multiset<_Key, _Compare, _Allocator>,
 
   47       typedef _GLIBCXX_STD_C::multiset<_Key, _Compare, _Allocator> 
_Base;
 
   54       typedef _Key                   key_type;
 
   55       typedef _Key                   value_type;
 
   56       typedef _Compare                   key_compare;
 
   57       typedef _Compare                   value_compare;
 
   58       typedef _Allocator                 allocator_type;
 
   59       typedef typename _Base::reference              reference;
 
   60       typedef typename _Base::const_reference        const_reference;
 
   67       typedef typename _Base::size_type              size_type;
 
   68       typedef typename _Base::difference_type        difference_type;
 
   69       typedef typename _Base::pointer                pointer;
 
   70       typedef typename _Base::const_pointer          const_pointer;
 
   75       explicit multiset(
const _Compare& __comp = _Compare(),
 
   76             const _Allocator& __a = _Allocator())
 
   77       : 
_Base(__comp, __a) { }
 
   79       template<
typename _InputIterator>
 
   80         multiset(_InputIterator __first, _InputIterator __last,
 
   81          const _Compare& __comp = _Compare(),
 
   82          const _Allocator& __a = _Allocator())
 
   94 #if __cplusplus >= 201103L 
   96       noexcept(is_nothrow_copy_constructible<_Compare>::value)
 
   97       : 
_Base(std::move(__x))
 
  101            const _Compare& __comp = _Compare(),
 
  102            const allocator_type& __a = allocator_type())
 
  103       : 
_Base(__l, __comp, __a) { }
 
  111     *
static_cast<_Base*
>(
this) = __x;
 
  112     this->_M_invalidate_all();
 
  116 #if __cplusplus >= 201103L 
  122     __glibcxx_check_self_move_assign(__x);
 
  137       using _Base::get_allocator;
 
  141       begin() _GLIBCXX_NOEXCEPT
 
  142       { 
return iterator(_Base::begin(), 
this); }
 
  145       begin() 
const _GLIBCXX_NOEXCEPT
 
  149       end() _GLIBCXX_NOEXCEPT
 
  150       { 
return iterator(_Base::end(), 
this); }
 
  153       end() 
const _GLIBCXX_NOEXCEPT
 
  157       rbegin() _GLIBCXX_NOEXCEPT
 
  161       rbegin() 
const _GLIBCXX_NOEXCEPT
 
  165       rend() _GLIBCXX_NOEXCEPT
 
  169       rend() 
const _GLIBCXX_NOEXCEPT
 
  172 #if __cplusplus >= 201103L 
  174       cbegin() 
const noexcept
 
  178       cend() 
const noexcept
 
  182       crbegin() 
const noexcept
 
  186       crend() 
const noexcept
 
  193       using _Base::max_size;
 
  196 #if __cplusplus >= 201103L 
  197       template<
typename... _Args>
 
  199     emplace(_Args&&... __args)
 
  201       return iterator(_Base::emplace(std::forward<_Args>(__args)...), 
this);
 
  204       template<
typename... _Args>
 
  210                           std::forward<_Args>(__args)...),
 
  216       insert(
const value_type& __x)
 
  217       { 
return iterator(_Base::insert(__x), 
this); }
 
  219 #if __cplusplus >= 201103L 
  221       insert(value_type&& __x)
 
  222       { 
return iterator(_Base::insert(std::move(__x)), 
this); }
 
  229     return iterator(_Base::insert(__position.
base(), __x), 
this);
 
  232 #if __cplusplus >= 201103L 
  237     return iterator(_Base::insert(__position.
base(), std::move(__x)),
 
  242       template<
typename _InputIterator>
 
  244     insert(_InputIterator __first, _InputIterator __last)
 
  246       __glibcxx_check_valid_range(__first, __last);
 
  251 #if __cplusplus >= 201103L 
  254       { _Base::insert(__l); }
 
  257 #if __cplusplus >= 201103L 
  271     _Base::erase(__position.
base());
 
  276       erase(
const key_type& __x)
 
  279       _Base::equal_range(__x);
 
  280     size_type __count = 0;
 
  282     while (__victim != __victims.
second)
 
  285         _Base::erase(__victim++);
 
  291 #if __cplusplus >= 201103L 
  299          __victim != __last.
base(); ++__victim)
 
  301         _GLIBCXX_DEBUG_VERIFY(__victim != _Base::end(),
 
  302                   _M_message(__gnu_debug::__msg_valid_range)
 
  303                   ._M_iterator(__first, 
"first")
 
  304                   ._M_iterator(__last, 
"last"));
 
  317          __victim != __last.
base(); ++__victim)
 
  319         _GLIBCXX_DEBUG_VERIFY(__victim != _Base::end(),
 
  320                   _M_message(__gnu_debug::__msg_valid_range)
 
  321                   ._M_iterator(__first, 
"first")
 
  322                   ._M_iterator(__last, 
"last"));
 
  325     _Base::erase(__first.
base(), __last.
base());
 
  337       clear() _GLIBCXX_NOEXCEPT
 
  339     this->_M_invalidate_all();
 
  344       using _Base::key_comp;
 
  345       using _Base::value_comp;
 
  349       find(
const key_type& __x)
 
  350       { 
return iterator(_Base::find(__x), 
this); }
 
  355       find(
const key_type& __x)
 const 
  361       lower_bound(
const key_type& __x)
 
  362       { 
return iterator(_Base::lower_bound(__x), 
this); }
 
  367       lower_bound(
const key_type& __x)
 const 
  371       upper_bound(
const key_type& __x)
 
  372       { 
return iterator(_Base::upper_bound(__x), 
this); }
 
  377       upper_bound(
const key_type& __x)
 const 
  381       equal_range(
const key_type& __x)
 
  384       _Base::equal_range(__x);
 
  392       equal_range(
const key_type& __x)
 const 
  395       _Base::equal_range(__x);
 
  401       _M_base() _GLIBCXX_NOEXCEPT       { 
return *
this; }
 
  404       _M_base() 
const _GLIBCXX_NOEXCEPT { 
return *
this; }
 
  415   template<
typename _Key, 
typename _Compare, 
typename _Allocator>
 
  419     { 
return __lhs._M_base() == __rhs._M_base(); }
 
  421   template<
typename _Key, 
typename _Compare, 
typename _Allocator>
 
  425     { 
return __lhs._M_base() != __rhs._M_base(); }
 
  427   template<
typename _Key, 
typename _Compare, 
typename _Allocator>
 
  429     operator<(const multiset<_Key, _Compare, _Allocator>& __lhs,
 
  430           const multiset<_Key, _Compare, _Allocator>& __rhs)
 
  431     { 
return __lhs._M_base() < __rhs._M_base(); }
 
  433   template<
typename _Key, 
typename _Compare, 
typename _Allocator>
 
  435     operator<=(const multiset<_Key, _Compare, _Allocator>& __lhs,
 
  436            const multiset<_Key, _Compare, _Allocator>& __rhs)
 
  437     { 
return __lhs._M_base() <= __rhs._M_base(); }
 
  439   template<
typename _Key, 
typename _Compare, 
typename _Allocator>
 
  441     operator>=(
const multiset<_Key, _Compare, _Allocator>& __lhs,
 
  442            const multiset<_Key, _Compare, _Allocator>& __rhs)
 
  443     { 
return __lhs._M_base() >= __rhs._M_base(); }
 
  445   template<
typename _Key, 
typename _Compare, 
typename _Allocator>
 
  447     operator>(
const multiset<_Key, _Compare, _Allocator>& __lhs,
 
  448           const multiset<_Key, _Compare, _Allocator>& __rhs)
 
  449     { 
return __lhs._M_base() > __rhs._M_base(); }
 
  451   template<
typename _Key, 
typename _Compare, 
typename _Allocator>
 
  453     swap(multiset<_Key, _Compare, _Allocator>& __x,
 
  454      multiset<_Key, _Compare, _Allocator>& __y)
 
  455     { 
return __x.swap(__y); }
 
void _M_swap(_Safe_sequence_base &__x)
 
_T2 second
first is a copy of the first object 
 
void _M_invalidate_if(_Predicate __pred)
 
#define __glibcxx_check_insert(_Position)
 
constexpr pair< typename __decay_and_strip< _T1 >::__type, typename __decay_and_strip< _T2 >::__type > make_pair(_T1 &&__x, _T2 &&__y)
A convenience wrapper for creating a pair from two objects. 
 
_T1 first
second_type is the second bound type 
 
constexpr size_t size() const noexcept
Returns the total number of bits. 
 
Struct holding two objects of arbitrary type. 
 
Class std::multiset with safety/checking/debug instrumentation. 
 
size_t count() const noexcept
Returns the number of bits which are set. 
 
_Iterator base() const noexcept
Return the underlying iterator. 
 
#define __glibcxx_check_erase(_Position)
 
A standard container made up of elements, which can be retrieved in logarithmic time. 
 
void swap(function< _Res(_Args...)> &__x, function< _Res(_Args...)> &__y)
Swap the targets of two polymorphic function object wrappers. 
 
Base class for constructing a safe sequence type that tracks iterators that reference it...
 
_Siter_base< _Iterator >::iterator_type __base(_Iterator __it)
 
#define __glibcxx_check_erase_range(_First, _Last)