62#pragma GCC system_header
71#if __cplusplus >= 201103L
74#ifdef __glibcxx_node_extract
78#if __cplusplus < 201103L
79# undef _GLIBCXX_USE_ALLOC_PTR_FOR_RB_TREE
80# define _GLIBCXX_USE_ALLOC_PTR_FOR_RB_TREE 0
81#elif ! defined _GLIBCXX_USE_ALLOC_PTR_FOR_RB_TREE
82# define _GLIBCXX_USE_ALLOC_PTR_FOR_RB_TREE 1
85namespace std _GLIBCXX_VISIBILITY(default)
87_GLIBCXX_BEGIN_NAMESPACE_VERSION
105 enum _Rb_tree_color { _S_red =
false, _S_black =
true };
107 struct _Rb_tree_node_base
109 typedef _Rb_tree_node_base* _Base_ptr;
111 _Rb_tree_color _M_color;
117 _S_minimum(_Base_ptr __x) _GLIBCXX_NOEXCEPT
119 while (__x->_M_left != 0) __x = __x->_M_left;
124 _S_maximum(_Base_ptr __x) _GLIBCXX_NOEXCEPT
126 while (__x->_M_right != 0) __x = __x->_M_right;
134 _M_base_ptr() const _GLIBCXX_NOEXCEPT
135 {
return const_cast<_Rb_tree_node_base*
>(
this); }
139 template<
typename _Key_compare>
140 struct _Rb_tree_key_compare
142 _Key_compare _M_key_compare;
144 _Rb_tree_key_compare()
145 _GLIBCXX_NOEXCEPT_IF(
146 is_nothrow_default_constructible<_Key_compare>::value)
150 _Rb_tree_key_compare(
const _Key_compare& __comp)
151 : _M_key_compare(__comp)
154#if __cplusplus >= 201103L
156 _Rb_tree_key_compare(
const _Rb_tree_key_compare&) =
default;
158 _Rb_tree_key_compare(_Rb_tree_key_compare&& __x)
159 noexcept(is_nothrow_copy_constructible<_Key_compare>::value)
160 : _M_key_compare(__x._M_key_compare)
166 struct _Rb_tree_header
168 _Rb_tree_node_base _M_header;
169 size_t _M_node_count;
171 _Rb_tree_header() _GLIBCXX_NOEXCEPT
173 _M_header._M_color = _S_red;
177#if __cplusplus >= 201103L
178 _Rb_tree_header(_Rb_tree_header&& __x)
noexcept
180 if (__x._M_header._M_parent !=
nullptr)
184 _M_header._M_color = _S_red;
191 _M_move_data(_Rb_tree_header& __from)
193 _M_header._M_color = __from._M_header._M_color;
194 _M_header._M_parent = __from._M_header._M_parent;
195 _M_header._M_left = __from._M_header._M_left;
196 _M_header._M_right = __from._M_header._M_right;
197 _M_header._M_parent->_M_parent = &_M_header;
198 _M_node_count = __from._M_node_count;
206 _M_header._M_parent = 0;
207 _M_header._M_left = &_M_header;
208 _M_header._M_right = &_M_header;
213 template<
typename _Val>
214 struct _Rb_tree_node :
public _Rb_tree_node_base
216#if __cplusplus < 201103L
227 __gnu_cxx::__aligned_membuf<_Val> _M_storage;
231 {
return _M_storage._M_ptr(); }
235 {
return _M_storage._M_ptr(); }
239 _M_node_ptr() _GLIBCXX_NOEXCEPT
243#if _GLIBCXX_USE_ALLOC_PTR_FOR_RB_TREE
246 template<
typename _Vo
idPtr>
249 using _Base_ptr = __ptr_rebind<_VoidPtr, _Node_base>;
251 _Rb_tree_color _M_color;
257 _S_minimum(_Base_ptr __x) _GLIBCXX_NOEXCEPT
259 while (__x->_M_left) __x = __x->_M_left;
264 _S_maximum(_Base_ptr __x) _GLIBCXX_NOEXCEPT
266 while (__x->_M_right) __x = __x->_M_right;
274 _M_base_ptr() const noexcept
276 return pointer_traits<_Base_ptr>::pointer_to
277 (*
const_cast<_Node_base*
>(
this));
282 template<
typename _NodeBase>
286 using _Base_ptr =
typename _NodeBase::_Base_ptr;
290 size_t _M_node_count;
294 _M_header._M_color = _S_red;
298 _Header(_Header&& __x)
noexcept
300 if (__x._M_header._M_parent)
304 _M_header._M_color = _S_red;
310 _M_move_data(_Header& __from)
312 _M_header._M_color = __from._M_header._M_color;
313 _M_header._M_parent = __from._M_header._M_parent;
314 _M_header._M_left = __from._M_header._M_left;
315 _M_header._M_right = __from._M_header._M_right;
316 _M_header._M_parent->_M_parent = _M_header._M_base_ptr();
317 _M_node_count = __from._M_node_count;
325 _M_header._M_parent =
nullptr;
326 _M_header._M_left = _M_header._M_right = _M_header._M_base_ptr();
331 template<
typename _ValPtr>
332 struct _Node :
public __rb_tree::_Node_base<__ptr_rebind<_ValPtr, void>>
334 using value_type =
typename pointer_traits<_ValPtr>::element_type;
339 _Node(_Node&&) =
delete;
341 union _Uninit_storage
343 _Uninit_storage() noexcept { }
344 ~_Uninit_storage() { }
348 _Uninit_storage _M_u;
359 _M_node_ptr() noexcept
360 {
return pointer_traits<_Node_ptr>::pointer_to(*
this); }
365 _GLIBCXX_PURE _Rb_tree_node_base*
366 _Rb_tree_increment(_Rb_tree_node_base* __x)
throw ();
368 _GLIBCXX_PURE _Rb_tree_node_base*
369 _Rb_tree_decrement(_Rb_tree_node_base* __x)
throw ();
371 template<
typename _Tp>
372 struct _Rb_tree_iterator
374 typedef _Tp value_type;
375 typedef _Tp& reference;
376 typedef _Tp* pointer;
378 typedef bidirectional_iterator_tag iterator_category;
379 typedef ptrdiff_t difference_type;
381 typedef _Rb_tree_node_base::_Base_ptr _Base_ptr;
382 typedef _Rb_tree_node<_Tp>* _Node_ptr;
384 _Rb_tree_iterator() _GLIBCXX_NOEXCEPT
388 _Rb_tree_iterator(_Base_ptr __x) _GLIBCXX_NOEXCEPT
392 operator*() const _GLIBCXX_NOEXCEPT
393 {
return *
static_cast<_Node_ptr
>(_M_node)->_M_valptr(); }
396 operator->() const _GLIBCXX_NOEXCEPT
397 {
return static_cast<_Node_ptr
>(_M_node)->_M_valptr(); }
400 operator++() _GLIBCXX_NOEXCEPT
402 _M_node = _Rb_tree_increment(_M_node);
407 operator++(
int) _GLIBCXX_NOEXCEPT
409 _Rb_tree_iterator __tmp = *
this;
410 _M_node = _Rb_tree_increment(_M_node);
415 operator--() _GLIBCXX_NOEXCEPT
417 _M_node = _Rb_tree_decrement(_M_node);
422 operator--(
int) _GLIBCXX_NOEXCEPT
424 _Rb_tree_iterator __tmp = *
this;
425 _M_node = _Rb_tree_decrement(_M_node);
430 operator==(
const _Rb_tree_iterator& __x,
431 const _Rb_tree_iterator& __y) _GLIBCXX_NOEXCEPT
432 {
return __x._M_node == __y._M_node; }
434#if ! __cpp_lib_three_way_comparison
436 operator!=(
const _Rb_tree_iterator& __x,
437 const _Rb_tree_iterator& __y) _GLIBCXX_NOEXCEPT
438 {
return __x._M_node != __y._M_node; }
444 template<
typename _Tp>
445 struct _Rb_tree_const_iterator
447 typedef _Tp value_type;
448 typedef const _Tp& reference;
449 typedef const _Tp* pointer;
451 typedef _Rb_tree_iterator<_Tp> iterator;
453 typedef bidirectional_iterator_tag iterator_category;
454 typedef ptrdiff_t difference_type;
456 typedef _Rb_tree_node_base::_Base_ptr _Base_ptr;
457 typedef const _Rb_tree_node<_Tp>* _Node_ptr;
459 _Rb_tree_const_iterator() _GLIBCXX_NOEXCEPT
463 _Rb_tree_const_iterator(_Base_ptr __x) _GLIBCXX_NOEXCEPT
466 _Rb_tree_const_iterator(
const iterator& __it) _GLIBCXX_NOEXCEPT
467 : _M_node(__it._M_node) { }
470 operator*() const _GLIBCXX_NOEXCEPT
471 {
return *
static_cast<_Node_ptr
>(_M_node)->_M_valptr(); }
474 operator->() const _GLIBCXX_NOEXCEPT
475 {
return static_cast<_Node_ptr
>(_M_node)->_M_valptr(); }
477 _Rb_tree_const_iterator&
478 operator++() _GLIBCXX_NOEXCEPT
480 _M_node = _Rb_tree_increment(_M_node);
484 _Rb_tree_const_iterator
485 operator++(
int) _GLIBCXX_NOEXCEPT
487 _Rb_tree_const_iterator __tmp = *
this;
488 _M_node = _Rb_tree_increment(_M_node);
492 _Rb_tree_const_iterator&
493 operator--() _GLIBCXX_NOEXCEPT
495 _M_node = _Rb_tree_decrement(_M_node);
499 _Rb_tree_const_iterator
500 operator--(
int) _GLIBCXX_NOEXCEPT
502 _Rb_tree_const_iterator __tmp = *
this;
503 _M_node = _Rb_tree_decrement(_M_node);
508 operator==(
const _Rb_tree_const_iterator& __x,
509 const _Rb_tree_const_iterator& __y) _GLIBCXX_NOEXCEPT
510 {
return __x._M_node == __y._M_node; }
512#if ! __cpp_lib_three_way_comparison
514 operator!=(
const _Rb_tree_const_iterator& __x,
515 const _Rb_tree_const_iterator& __y) _GLIBCXX_NOEXCEPT
516 {
return __x._M_node != __y._M_node; }
522 __attribute__((__nonnull__))
524 _Rb_tree_insert_and_rebalance(
const bool __insert_left,
525 _Rb_tree_node_base* __x,
526 _Rb_tree_node_base* __p,
527 _Rb_tree_node_base& __header)
throw ();
529 __attribute__((__nonnull__,__returns_nonnull__))
531 _Rb_tree_rebalance_for_erase(_Rb_tree_node_base*
const __z,
532 _Rb_tree_node_base& __header)
throw ();
536#if _GLIBCXX_USE_ALLOC_PTR_FOR_RB_TREE
537 template<
bool _Const,
typename _ValPtr>
540 template<
typename _Tp>
541 using __maybe_const = __conditional_t<_Const, const _Tp, _Tp>;
543 using __ptr_traits = pointer_traits<_ValPtr>;
544 using value_type =
typename __ptr_traits::element_type;
545 using reference = __maybe_const<value_type>&;
546 using pointer = __maybe_const<value_type>*;
548 using iterator_category = bidirectional_iterator_tag;
549 using difference_type = ptrdiff_t;
551 using _Node = __rb_tree::_Node<_ValPtr>;
552 using _Node_base = __rb_tree::_Node_base<__ptr_rebind<_ValPtr, void>>;
553 using _Base_ptr =
typename _Node_base::_Base_ptr;
559 _Iterator(_Base_ptr __x) noexcept
562 _Iterator(
const _Iterator&) =
default;
563 _Iterator& operator=(
const _Iterator&) =
default;
565#ifdef __glibcxx_concepts
567 _Iterator(
const _Iterator<false, _ValPtr>& __it)
requires _Const
569 template<
bool _OtherConst,
570 typename = __enable_if_t<_Const && !_OtherConst>>
572 _Iterator(
const _Iterator<_OtherConst, _ValPtr>& __it)
574 : _M_node(__it._M_node) { }
578 operator*() const noexcept
579 {
return *
static_cast<_Node&
>(*_M_node)._M_valptr(); }
583 operator->() const noexcept
584 {
return static_cast<_Node&
>(*_M_node)._M_valptr(); }
586 _GLIBCXX14_CONSTEXPR _Iterator&
587 operator++() noexcept
589 if (_M_node->_M_right)
591 _M_node = _M_node->_M_right;
592 while (_M_node->_M_left)
593 _M_node = _M_node->_M_left;
597 _Base_ptr __y = _M_node->_M_parent;
598 while (_M_node == __y->_M_right)
601 __y = __y->_M_parent;
603 if (_M_node->_M_right != __y)
610 _GLIBCXX14_CONSTEXPR _Iterator
611 operator++(
int)
noexcept
613 _Iterator __tmp(this->_M_node);
618 _GLIBCXX14_CONSTEXPR _Iterator&
619 operator--() noexcept
621 if (_M_node->_M_color == _S_red
622 && _M_node->_M_parent->_M_parent == _M_node)
623 _M_node = _M_node->_M_right;
624 else if (_M_node->_M_left)
626 _Base_ptr __y = _M_node->_M_left;
627 while (__y->_M_right)
633 _Base_ptr __y = _M_node->_M_parent;
634 while (_M_node == __y->_M_left)
637 __y = __y->_M_parent;
644 _GLIBCXX14_CONSTEXPR _Iterator
645 operator--(
int)
noexcept
647 _Iterator __tmp(this->_M_node);
654 operator==(
const _Iterator& __x,
const _Iterator& __y) _GLIBCXX_NOEXCEPT
655 {
return __x._M_node == __y._M_node; }
657#if ! __cpp_lib_three_way_comparison
660 operator!=(
const _Iterator& __x,
const _Iterator& __y) _GLIBCXX_NOEXCEPT
661 {
return __x._M_node != __y._M_node; }
669 template<
typename _Val,
typename _Ptr>
672#if _GLIBCXX_USE_ALLOC_PTR_FOR_RB_TREE <= 9000
676 template<
typename _Val>
677 struct _Node_traits<_Val, _Val*>
679 typedef _Rb_tree_node<_Val> _Node;
680 typedef _Node* _Node_ptr;
681 typedef _Rb_tree_node_base _Node_base;
682 typedef _Node_base* _Base_ptr;
683 typedef _Rb_tree_header _Header_t;
684 typedef _Rb_tree_iterator<_Val> _Iterator;
685 typedef _Rb_tree_const_iterator<_Val> _Const_iterator;
687 __attribute__((__nonnull__))
689 _S_insert_and_rebalance(
const bool __insert_left,
690 _Node_base* __x, _Node_base* __p,
691 _Node_base& __header) _GLIBCXX_USE_NOEXCEPT
693 return _Rb_tree_insert_and_rebalance(__insert_left, __x, __p, __header);
696 __attribute__((__nonnull__,__returns_nonnull__))
698 _S_rebalance_for_erase(_Node_base*
const __z,
699 _Node_base& __header) _GLIBCXX_USE_NOEXCEPT
700 {
return _Rb_tree_rebalance_for_erase(__z, __header); }
704#if ! _GLIBCXX_USE_ALLOC_PTR_FOR_RB_TREE
706 template<
typename _Val,
typename _Ptr>
708 : _Node_traits<_Val, _Val*>
712 template<
typename _Val,
typename _ValPtr>
715 using _Node = __rb_tree::_Node<_ValPtr>;
717 using _Node_base = __rb_tree::_Node_base<__ptr_rebind<_ValPtr, void>>;
719 using _Header_t = __rb_tree::_Header<_Node_base>;
720 using _Iterator = __rb_tree::_Iterator<false, _ValPtr>;
721 using _Const_iterator = __rb_tree::_Iterator<true, _ValPtr>;
724 _Rotate_left(_Base_ptr __x, _Base_ptr& __root)
726 const _Base_ptr __y = __x->_M_right;
728 __x->_M_right = __y->_M_left;
730 __y->_M_left->_M_parent = __x;
731 __y->_M_parent = __x->_M_parent;
735 else if (__x == __x->_M_parent->_M_left)
736 __x->_M_parent->_M_left = __y;
738 __x->_M_parent->_M_right = __y;
740 __x->_M_parent = __y;
744 _Rotate_right(_Base_ptr __x, _Base_ptr& __root)
746 const _Base_ptr __y = __x->_M_left;
748 __x->_M_left = __y->_M_right;
750 __y->_M_right->_M_parent = __x;
751 __y->_M_parent = __x->_M_parent;
755 else if (__x == __x->_M_parent->_M_right)
756 __x->_M_parent->_M_right = __y;
758 __x->_M_parent->_M_left = __y;
760 __x->_M_parent = __y;
764 _S_insert_and_rebalance(
const bool __insert_left,
765 _Base_ptr __x, _Base_ptr __p,
766 _Node_base& __header)
768 _Base_ptr& __root = __header._M_parent;
771 __x->_M_parent = __p;
772 __x->_M_left = __x->_M_right =
nullptr;
773 __x->_M_color = _S_red;
785 __header._M_parent = __x;
786 __header._M_right = __x;
788 else if (__p == __header._M_left)
789 __header._M_left = __x;
795 if (__p == __header._M_right)
796 __header._M_right = __x;
800 && __x->_M_parent->_M_color == _S_red)
802 const _Base_ptr __xpp = __x->_M_parent->_M_parent;
804 if (__x->_M_parent == __xpp->_M_left)
806 const _Base_ptr __y = __xpp->_M_right;
807 if (__y && __y->_M_color == _S_red)
809 __x->_M_parent->_M_color = _S_black;
810 __y->_M_color = _S_black;
811 __xpp->_M_color = _S_red;
816 if (__x == __x->_M_parent->_M_right)
818 __x = __x->_M_parent;
819 _Rotate_left(__x, __root);
821 __x->_M_parent->_M_color = _S_black;
822 __xpp->_M_color = _S_red;
823 _Rotate_right(__xpp, __root);
828 const _Base_ptr __y = __xpp->_M_left;
829 if (__y && __y->_M_color == _S_red)
831 __x->_M_parent->_M_color = _S_black;
832 __y->_M_color = _S_black;
833 __xpp->_M_color = _S_red;
838 if (__x == __x->_M_parent->_M_left)
840 __x = __x->_M_parent;
841 _Rotate_right(__x, __root);
843 __x->_M_parent->_M_color = _S_black;
844 __xpp->_M_color = _S_red;
845 _Rotate_left(__xpp, __root);
849 __root->_M_color = _S_black;
853 _S_rebalance_for_erase(_Base_ptr __z, _Node_base& __header)
855 _Base_ptr& __root = __header._M_parent;
856 _Base_ptr& __leftmost = __header._M_left;
857 _Base_ptr& __rightmost = __header._M_right;
860 _Base_ptr __x_parent{};
878 __z->_M_left->_M_parent = __y;
879 __y->_M_left = __z->_M_left;
880 if (__y != __z->_M_right)
882 __x_parent = __y->_M_parent;
884 __x->_M_parent = __y->_M_parent;
885 __y->_M_parent->_M_left = __x;
886 __y->_M_right = __z->_M_right;
887 __z->_M_right->_M_parent = __y;
893 else if (__z->_M_parent->_M_left == __z)
894 __z->_M_parent->_M_left = __y;
896 __z->_M_parent->_M_right = __y;
897 __y->_M_parent = __z->_M_parent;
898 std::swap(__y->_M_color, __z->_M_color);
904 __x_parent = __y->_M_parent;
906 __x->_M_parent = __y->_M_parent;
910 if (__z->_M_parent->_M_left == __z)
911 __z->_M_parent->_M_left = __x;
913 __z->_M_parent->_M_right = __x;
914 if (__leftmost == __z)
917 __leftmost = __z->_M_parent;
920 __leftmost = _Node_base::_S_minimum(__x);
922 if (__rightmost == __z)
924 if (__z->_M_left == 0)
925 __rightmost = __z->_M_parent;
928 __rightmost = _Node_base::_S_maximum(__x);
931 if (__y->_M_color != _S_red)
933 while (__x != __root && (__x == 0 || __x->_M_color == _S_black))
934 if (__x == __x_parent->_M_left)
936 _Base_ptr __w = __x_parent->_M_right;
937 if (__w->_M_color == _S_red)
939 __w->_M_color = _S_black;
940 __x_parent->_M_color = _S_red;
941 _Rotate_left(__x_parent, __root);
942 __w = __x_parent->_M_right;
944 if ((!__w->_M_left || __w->_M_left->_M_color == _S_black) &&
945 (!__w->_M_right || __w->_M_right->_M_color == _S_black))
947 __w->_M_color = _S_red;
949 __x_parent = __x_parent->_M_parent;
953 if (!__w->_M_right || __w->_M_right->_M_color == _S_black)
955 __w->_M_left->_M_color = _S_black;
956 __w->_M_color = _S_red;
957 _Rotate_right(__w, __root);
958 __w = __x_parent->_M_right;
960 __w->_M_color = __x_parent->_M_color;
961 __x_parent->_M_color = _S_black;
963 __w->_M_right->_M_color = _S_black;
964 _Rotate_left(__x_parent, __root);
971 _Base_ptr __w = __x_parent->_M_left;
972 if (__w->_M_color == _S_red)
974 __w->_M_color = _S_black;
975 __x_parent->_M_color = _S_red;
976 _Rotate_right(__x_parent, __root);
977 __w = __x_parent->_M_left;
979 if ((!__w->_M_right || __w->_M_right->_M_color == _S_black) &&
980 (!__w->_M_left || __w->_M_left->_M_color == _S_black))
982 __w->_M_color = _S_red;
984 __x_parent = __x_parent->_M_parent;
988 if (!__w->_M_left || __w->_M_left->_M_color == _S_black)
990 __w->_M_right->_M_color = _S_black;
991 __w->_M_color = _S_red;
992 _Rotate_left(__w, __root);
993 __w = __x_parent->_M_left;
995 __w->_M_color = __x_parent->_M_color;
996 __x_parent->_M_color = _S_black;
998 __w->_M_left->_M_color = _S_black;
999 _Rotate_right(__x_parent, __root);
1004 __x->_M_color = _S_black;
1013#ifdef __glibcxx_node_extract
1014 template<
typename _Tree1,
typename _Cmp2>
1015 struct _Rb_tree_merge_helper { };
1018 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
1022 typedef typename __gnu_cxx::__alloc_traits<_Alloc>::template
1023 rebind<_Val>::other _Val_alloc_type;
1025 typedef __gnu_cxx::__alloc_traits<_Val_alloc_type> _Val_alloc_traits;
1026 typedef typename _Val_alloc_traits::pointer _ValPtr;
1027 typedef __rb_tree::_Node_traits<_Val, _ValPtr> _Node_traits;
1029 typedef typename _Node_traits::_Node_base _Node_base;
1030 typedef typename _Node_traits::_Node _Node;
1032 typedef typename __gnu_cxx::__alloc_traits<_Alloc>::template
1033 rebind<_Node>::other _Node_allocator;
1035 typedef __gnu_cxx::__alloc_traits<_Node_allocator> _Node_alloc_traits;
1038 typedef typename _Node_traits::_Base_ptr _Base_ptr;
1039 typedef typename _Node_traits::_Node_ptr _Node_ptr;
1044 struct _Reuse_or_alloc_node
1046 _Reuse_or_alloc_node(_Rb_tree& __t)
1047 : _M_root(__t._M_root()), _M_nodes(__t._M_rightmost()), _M_t(__t)
1051 _M_root->_M_parent = _Base_ptr();
1053 if (_M_nodes->_M_left)
1054 _M_nodes = _M_nodes->_M_left;
1057 _M_nodes = _Base_ptr();
1060#if __cplusplus >= 201103L
1061 _Reuse_or_alloc_node(
const _Reuse_or_alloc_node&) =
delete;
1064 ~_Reuse_or_alloc_node()
1067 _M_t._M_erase(
static_cast<_Node&
>(*_M_root)._M_node_ptr());
1070 template<
typename _Arg>
1072 operator()(_GLIBCXX_FWDREF(_Arg) __arg)
1074 _Base_ptr
__base = _M_extract();
1077 _Node_ptr __node =
static_cast<_Node&
>(*__base)._M_node_ptr();
1078 _M_t._M_destroy_node(__node);
1079 _M_t._M_construct_node(__node, _GLIBCXX_FORWARD(_Arg, __arg));
1083 return _M_t._M_create_node(_GLIBCXX_FORWARD(_Arg, __arg));
1093 _Base_ptr __node = _M_nodes;
1094 _M_nodes = _M_nodes->_M_parent;
1097 if (_M_nodes->_M_right == __node)
1099 _M_nodes->_M_right = _Base_ptr();
1101 if (_M_nodes->_M_left)
1103 _M_nodes = _M_nodes->_M_left;
1105 while (_M_nodes->_M_right)
1106 _M_nodes = _M_nodes->_M_right;
1108 if (_M_nodes->_M_left)
1109 _M_nodes = _M_nodes->_M_left;
1113 _M_nodes->_M_left = _Base_ptr();
1116 _M_root = _Base_ptr();
1130 _Alloc_node(_Rb_tree& __t)
1133 template<
typename _Arg>
1135 operator()(_GLIBCXX_FWDREF(_Arg) __arg)
const
1136 {
return _M_t._M_create_node(_GLIBCXX_FORWARD(_Arg, __arg)); }
1143 typedef _Key key_type;
1144 typedef _Val value_type;
1145 typedef value_type* pointer;
1146 typedef const value_type* const_pointer;
1147 typedef value_type& reference;
1148 typedef const value_type& const_reference;
1149 typedef size_t size_type;
1150 typedef ptrdiff_t difference_type;
1151 typedef _Alloc allocator_type;
1154 _M_get_Node_allocator() _GLIBCXX_NOEXCEPT
1155 {
return this->_M_impl; }
1157 const _Node_allocator&
1158 _M_get_Node_allocator() const _GLIBCXX_NOEXCEPT
1159 {
return this->_M_impl; }
1162 get_allocator() const _GLIBCXX_NOEXCEPT
1163 {
return allocator_type(_M_get_Node_allocator()); }
1169#if __cplusplus < 201102L || _GLIBCXX_USE_ALLOC_PTR_FOR_RB_TREE
1172#pragma GCC diagnostic push
1173#pragma GCC diagnostic ignored "-Wc++17-extensions"
1174 using __alloc_pointer =
typename _Node_alloc_traits::pointer;
1175 if constexpr (is_same<_Node_ptr, __alloc_pointer>::value)
1181 return std::__to_address(__ptr);
1183#pragma GCC diagnostic pop
1188 _M_put_node(_Node_ptr __p) _GLIBCXX_NOEXCEPT
1190#if __cplusplus < 201102L || _GLIBCXX_USE_ALLOC_PTR_FOR_RB_TREE
1193#pragma GCC diagnostic push
1194#pragma GCC diagnostic ignored "-Wc++17-extensions"
1195 using __alloc_pointer =
typename _Node_alloc_traits::pointer;
1196 if constexpr (is_same<_Node_ptr, __alloc_pointer>::value)
1202 auto __ap = pointer_traits<__alloc_pointer>::pointer_to(*__p);
1205#pragma GCC diagnostic pop
1209#if __cplusplus < 201103L
1211 _M_construct_node(_Node_ptr __node,
const value_type& __x)
1214 { get_allocator().construct(__node->_M_valptr(), __x); }
1217 _M_put_node(__node);
1218 __throw_exception_again;
1223 _M_create_node(
const value_type& __x)
1225 _Node_ptr __tmp = _M_get_node();
1226 _M_construct_node(__tmp, __x);
1230 template<
typename... _Args>
1232 _M_construct_node(_Node_ptr __node, _Args&&... __args)
1237 _Node_alloc_traits::construct(_M_get_Node_allocator(),
1238 __node->_M_valptr(),
1244 _M_put_node(__node);
1245 __throw_exception_again;
1249 template<
typename... _Args>
1251 _M_create_node(_Args&&... __args)
1253 _Node_ptr __tmp = _M_get_node();
1260 _M_destroy_node(_Node_ptr __p) _GLIBCXX_NOEXCEPT
1262#if __cplusplus < 201103L
1263 get_allocator().destroy(__p->_M_valptr());
1265 _Node_alloc_traits::destroy(_M_get_Node_allocator(), __p->_M_valptr());
1271 _M_drop_node(_Node_ptr __p) _GLIBCXX_NOEXCEPT
1273 _M_destroy_node(__p);
1277 template<
bool _MoveValue,
typename _NodeGen>
1279 _M_clone_node(_Node_ptr __x, _NodeGen& __node_gen)
1281#if __cplusplus >= 201103L
1282 using _Vp = __conditional_t<_MoveValue,
1287 = __node_gen(_GLIBCXX_FORWARD(_Vp, *__x->_M_valptr()));
1288 __tmp->_M_color = __x->_M_color;
1289 __tmp->_M_left = __tmp->_M_right = _Base_ptr();
1294 typedef typename _Node_traits::_Header_t _Header_t;
1296#if _GLIBCXX_INLINE_VERSION
1297 template<
typename _Key_compare>
1300 template<
typename _Key_compare,
1301 bool = __is_pod(_Key_compare)>
1303 struct _Rb_tree_impl
1304 :
public _Node_allocator
1305 ,
public _Rb_tree_key_compare<_Key_compare>
1308 typedef _Rb_tree_key_compare<_Key_compare> _Base_key_compare;
1311 _GLIBCXX_NOEXCEPT_IF(
1312 is_nothrow_default_constructible<_Node_allocator>::value
1313 && is_nothrow_default_constructible<_Base_key_compare>::value )
1317 _Rb_tree_impl(
const _Rb_tree_impl& __x)
1318 : _Node_allocator(_Node_alloc_traits::_S_select_on_copy(__x))
1319 , _Base_key_compare(__x._M_key_compare)
1323#if __cplusplus < 201103L
1324 _Rb_tree_impl(
const _Key_compare& __comp,
const _Node_allocator& __a)
1325 : _Node_allocator(__a), _Base_key_compare(__comp)
1328 _Rb_tree_impl(_Rb_tree_impl&&)
1329 noexcept( is_nothrow_move_constructible<_Base_key_compare>::value )
1333 _Rb_tree_impl(_Node_allocator&& __a)
1334 : _Node_allocator(std::
move(__a))
1337 _Rb_tree_impl(_Rb_tree_impl&& __x, _Node_allocator&& __a)
1338 : _Node_allocator(std::
move(__a)),
1339 _Base_key_compare(std::
move(__x)),
1340 _Header_t(std::
move(__x))
1343 _Rb_tree_impl(
const _Key_compare& __comp, _Node_allocator&& __a)
1344 : _Node_allocator(std::
move(__a)), _Base_key_compare(__comp)
1349 _Rb_tree_impl<_Compare> _M_impl;
1353 _M_root() _GLIBCXX_NOEXCEPT
1354 {
return this->_M_impl._M_header._M_parent; }
1357 _M_root() const _GLIBCXX_NOEXCEPT
1358 {
return this->_M_impl._M_header._M_parent; }
1361 _M_leftmost() _GLIBCXX_NOEXCEPT
1362 {
return this->_M_impl._M_header._M_left; }
1365 _M_leftmost() const _GLIBCXX_NOEXCEPT
1366 {
return this->_M_impl._M_header._M_left; }
1369 _M_rightmost() _GLIBCXX_NOEXCEPT
1370 {
return this->_M_impl._M_header._M_right; }
1373 _M_rightmost() const _GLIBCXX_NOEXCEPT
1374 {
return this->_M_impl._M_header._M_right; }
1377 _M_begin() const _GLIBCXX_NOEXCEPT
1378 {
return this->_M_impl._M_header._M_parent; }
1381 _M_begin_node() const _GLIBCXX_NOEXCEPT
1383 _Base_ptr __begin = this->_M_impl._M_header._M_parent;
1385 ?
static_cast<_Node&
>(*__begin)._M_node_ptr()
1390 _M_end() const _GLIBCXX_NOEXCEPT
1391 {
return this->_M_impl._M_header._M_base_ptr(); }
1395 template<
typename _Key1,
typename _Key2>
1397 _M_key_compare(
const _Key1& __k1,
const _Key2& __k2)
const
1399#if __cplusplus >= 201103L
1402 __is_invocable<const _Compare&, const _Key&, const _Key&>::value,
1403 "comparison object must be invocable with two arguments of key type"
1406 return _M_impl._M_key_compare(__k1, __k2);
1410 _S_key(
const _Node& __node)
1411 {
return _KeyOfValue()(*__node._M_valptr()); }
1414 _S_key(_Base_ptr __x)
1415 {
return _S_key(
static_cast<const _Node&
>(*__x)); }
1418 _S_key(_Node_ptr __x)
1419 {
return _S_key(*__x); }
1422 _S_left(_Base_ptr __x) _GLIBCXX_NOEXCEPT
1423 {
return __x->_M_left; }
1426 _S_left(_Node_ptr __x)
1429 ?
static_cast<_Node&
>(*__x->_M_left)._M_node_ptr()
1434 _S_right(_Base_ptr __x) _GLIBCXX_NOEXCEPT
1435 {
return __x->_M_right; }
1438 _S_right(_Node_ptr __x) _GLIBCXX_NOEXCEPT
1440 return __x->_M_right
1441 ?
static_cast<_Node&
>(*__x->_M_right)._M_node_ptr()
1446 typedef typename _Node_traits::_Iterator iterator;
1447 typedef typename _Node_traits::_Const_iterator const_iterator;
1449 typedef std::reverse_iterator<iterator> reverse_iterator;
1450 typedef std::reverse_iterator<const_iterator> const_reverse_iterator;
1452#ifdef __glibcxx_node_extract
1453 using node_type = _Node_handle<_Key, _Val, _Node_allocator>;
1454 using insert_return_type = _Node_insert_return<
1455 __conditional_t<is_same_v<_Key, _Val>, const_iterator, iterator>,
1460 _M_get_insert_unique_pos(
const key_type& __k);
1463 _M_get_insert_equal_pos(
const key_type& __k);
1466 _M_get_insert_hint_unique_pos(const_iterator __pos,
1467 const key_type& __k);
1470 _M_get_insert_hint_equal_pos(const_iterator __pos,
1471 const key_type& __k);
1474#if __cplusplus >= 201103L
1475 template<
typename _Arg,
typename _NodeGen>
1477 _M_insert_(_Base_ptr __x, _Base_ptr __y, _Arg&& __v, _NodeGen&);
1480 _M_insert_node(_Base_ptr __x, _Base_ptr __y, _Node_ptr __z);
1482 template<
typename _Arg>
1484 _M_insert_lower(_Base_ptr __y, _Arg&& __v);
1486 template<
typename _Arg>
1488 _M_insert_equal_lower(_Arg&& __x);
1491 _M_insert_lower_node(_Base_ptr __p, _Node_ptr __z);
1494 _M_insert_equal_lower_node(_Node_ptr __z);
1496 template<
typename _NodeGen>
1498 _M_insert_(_Base_ptr __x, _Base_ptr __y,
1499 const value_type& __v, _NodeGen&);
1504 _M_insert_lower(_Base_ptr __y,
const value_type& __v);
1507 _M_insert_equal_lower(
const value_type& __x);
1510 enum { __as_lvalue, __as_rvalue };
1512 template<
bool _MoveValues,
typename _NodeGen>
1514 _M_copy(_Node_ptr, _Base_ptr, _NodeGen&);
1516 template<
bool _MoveValues,
typename _NodeGen>
1518 _M_copy(
const _Rb_tree& __x, _NodeGen& __gen)
1521 _M_copy<_MoveValues>(__x._M_begin_node(), _M_end(), __gen);
1522 _M_leftmost() = _Node_base::_S_minimum(__root);
1523 _M_rightmost() = _Node_base::_S_maximum(__root);
1524 _M_impl._M_node_count = __x._M_impl._M_node_count;
1529 _M_copy(
const _Rb_tree& __x)
1531 _Alloc_node __an(*
this);
1532 return _M_copy<__as_lvalue>(__x, __an);
1536 _M_erase(_Node_ptr __x);
1539 _M_lower_bound(_Base_ptr __x, _Base_ptr __y,
1540 const _Key& __k)
const;
1543 _M_upper_bound(_Base_ptr __x, _Base_ptr __y,
1544 const _Key& __k)
const;
1548#if __cplusplus < 201103L
1551 _Rb_tree() =
default;
1554 _Rb_tree(
const _Compare& __comp,
1555 const allocator_type& __a = allocator_type())
1556 : _M_impl(__comp, _Node_allocator(__a)) { }
1558 _Rb_tree(
const _Rb_tree& __x)
1559 : _M_impl(__x._M_impl)
1562 _M_root() = _M_copy(__x);
1565#if __cplusplus >= 201103L
1566 _Rb_tree(
const allocator_type& __a)
1567 : _M_impl(_Node_allocator(__a))
1570 _Rb_tree(
const _Rb_tree& __x,
const allocator_type& __a)
1571 : _M_impl(__x._M_impl._M_key_compare, _Node_allocator(__a))
1574 _M_root() = _M_copy(__x);
1577 _Rb_tree(_Rb_tree&&) =
default;
1579 _Rb_tree(_Rb_tree&& __x,
const allocator_type& __a)
1580 : _Rb_tree(std::
move(__x), _Node_allocator(__a))
1584 _Rb_tree(_Rb_tree&& __x, _Node_allocator&& __a,
true_type)
1585 noexcept(is_nothrow_default_constructible<_Compare>::value)
1586 : _M_impl(std::
move(__x._M_impl), std::
move(__a))
1589 _Rb_tree(_Rb_tree&& __x, _Node_allocator&& __a,
false_type)
1590 : _M_impl(__x._M_impl._M_key_compare, std::
move(__a))
1597 _Rb_tree(_Rb_tree&& __x, _Node_allocator&& __a)
1601 : _Rb_tree(std::
move(__x), std::
move(__a),
1602 typename _Node_alloc_traits::is_always_equal{})
1606 ~_Rb_tree() _GLIBCXX_NOEXCEPT
1607 { _M_erase(_M_begin_node()); }
1610 operator=(
const _Rb_tree& __x);
1615 {
return _M_impl._M_key_compare; }
1618 begin() _GLIBCXX_NOEXCEPT
1619 {
return iterator(this->_M_impl._M_header._M_left); }
1622 begin() const _GLIBCXX_NOEXCEPT
1623 {
return const_iterator(this->_M_impl._M_header._M_left); }
1626 end() _GLIBCXX_NOEXCEPT
1627 {
return iterator(_M_end()); }
1630 end() const _GLIBCXX_NOEXCEPT
1631 {
return const_iterator(_M_end()); }
1634 rbegin() _GLIBCXX_NOEXCEPT
1635 {
return reverse_iterator(end()); }
1637 const_reverse_iterator
1638 rbegin() const _GLIBCXX_NOEXCEPT
1639 {
return const_reverse_iterator(end()); }
1642 rend() _GLIBCXX_NOEXCEPT
1643 {
return reverse_iterator(begin()); }
1645 const_reverse_iterator
1646 rend() const _GLIBCXX_NOEXCEPT
1647 {
return const_reverse_iterator(begin()); }
1649 _GLIBCXX_NODISCARD
bool
1650 empty() const _GLIBCXX_NOEXCEPT
1651 {
return _M_impl._M_node_count == 0; }
1654 size() const _GLIBCXX_NOEXCEPT
1655 {
return _M_impl._M_node_count; }
1658 max_size() const _GLIBCXX_NOEXCEPT
1663 _GLIBCXX_NOEXCEPT_IF(__is_nothrow_swappable<_Compare>::value);
1666#if __cplusplus >= 201103L
1667 template<
typename _Arg>
1669 _M_insert_unique(_Arg&& __x);
1671 template<
typename _Arg>
1673 _M_insert_equal(_Arg&& __x);
1675 template<
typename _Arg,
typename _NodeGen>
1677 _M_insert_unique_(const_iterator __pos, _Arg&& __x, _NodeGen&);
1679 template<
typename _Arg>
1681 _M_insert_unique_(const_iterator __pos, _Arg&& __x)
1683 _Alloc_node __an(*
this);
1687 template<
typename _Arg,
typename _NodeGen>
1689 _M_insert_equal_(const_iterator __pos, _Arg&& __x, _NodeGen&);
1691 template<
typename _Arg>
1693 _M_insert_equal_(const_iterator __pos, _Arg&& __x)
1695 _Alloc_node __an(*
this);
1699 template<
typename... _Args>
1701 _M_emplace_unique(_Args&&... __args);
1703 template<
typename... _Args>
1705 _M_emplace_equal(_Args&&... __args);
1707 template<
typename... _Args>
1709 _M_emplace_hint_unique(const_iterator __pos, _Args&&... __args);
1711 template<
typename... _Args>
1713 _M_emplace_hint_equal(const_iterator __pos, _Args&&... __args);
1715 template<
typename _Iter>
1716 using __same_value_type
1717 = is_same<value_type, typename iterator_traits<_Iter>::value_type>;
1719 template<
typename _InputIterator>
1720 __enable_if_t<__same_value_type<_InputIterator>::value>
1721 _M_insert_range_unique(_InputIterator __first, _InputIterator __last)
1723 _Alloc_node __an(*
this);
1724 for (; __first != __last; ++__first)
1725 _M_insert_unique_(end(), *__first, __an);
1728 template<
typename _InputIterator>
1729 __enable_if_t<!__same_value_type<_InputIterator>::value>
1730 _M_insert_range_unique(_InputIterator __first, _InputIterator __last)
1732 for (; __first != __last; ++__first)
1733 _M_emplace_unique(*__first);
1736 template<
typename _InputIterator>
1737 __enable_if_t<__same_value_type<_InputIterator>::value>
1738 _M_insert_range_equal(_InputIterator __first, _InputIterator __last)
1740 _Alloc_node __an(*
this);
1741 for (; __first != __last; ++__first)
1742 _M_insert_equal_(end(), *__first, __an);
1745 template<
typename _InputIterator>
1746 __enable_if_t<!__same_value_type<_InputIterator>::value>
1747 _M_insert_range_equal(_InputIterator __first, _InputIterator __last)
1749 for (; __first != __last; ++__first)
1750 _M_emplace_equal(*__first);
1754 _M_insert_unique(
const value_type& __x);
1757 _M_insert_equal(
const value_type& __x);
1759 template<
typename _NodeGen>
1761 _M_insert_unique_(const_iterator __pos,
const value_type& __x,
1765 _M_insert_unique_(const_iterator __pos,
const value_type& __x)
1767 _Alloc_node __an(*
this);
1768 return _M_insert_unique_(__pos, __x, __an);
1771 template<
typename _NodeGen>
1773 _M_insert_equal_(const_iterator __pos,
const value_type& __x,
1776 _M_insert_equal_(const_iterator __pos,
const value_type& __x)
1778 _Alloc_node __an(*
this);
1779 return _M_insert_equal_(__pos, __x, __an);
1782 template<
typename _InputIterator>
1784 _M_insert_range_unique(_InputIterator __first, _InputIterator __last)
1786 _Alloc_node __an(*
this);
1787 for (; __first != __last; ++__first)
1788 _M_insert_unique_(end(), *__first, __an);
1791 template<
typename _InputIterator>
1793 _M_insert_range_equal(_InputIterator __first, _InputIterator __last)
1795 _Alloc_node __an(*
this);
1796 for (; __first != __last; ++__first)
1797 _M_insert_equal_(end(), *__first, __an);
1803 _M_erase_aux(const_iterator __position);
1806 _M_erase_aux(const_iterator __first, const_iterator __last);
1809#if __cplusplus >= 201103L
1812 _GLIBCXX_ABI_TAG_CXX11
1814 erase(const_iterator __position)
1816 __glibcxx_assert(__position != end());
1817 const_iterator __result = __position;
1819 _M_erase_aux(__position);
1820 return iterator(__result._M_node);
1824 _GLIBCXX_ABI_TAG_CXX11
1826 erase(iterator __position)
1828 __glibcxx_assert(__position != end());
1829 iterator __result = __position;
1831 _M_erase_aux(__position);
1836 erase(iterator __position)
1838 __glibcxx_assert(__position != end());
1839 _M_erase_aux(__position);
1843 erase(const_iterator __position)
1845 __glibcxx_assert(__position != end());
1846 _M_erase_aux(__position);
1851 erase(
const key_type& __x);
1854 _M_erase_unique(
const key_type& __x);
1856#if __cplusplus >= 201103L
1859 _GLIBCXX_ABI_TAG_CXX11
1861 erase(const_iterator __first, const_iterator __last)
1863 _M_erase_aux(__first, __last);
1864 return iterator(__last._M_node);
1868 erase(iterator __first, iterator __last)
1869 { _M_erase_aux(__first, __last); }
1872 erase(const_iterator __first, const_iterator __last)
1873 { _M_erase_aux(__first, __last); }
1877 clear() _GLIBCXX_NOEXCEPT
1879 _M_erase(_M_begin_node());
1885 find(
const key_type& __k);
1888 find(
const key_type& __k)
const;
1891 count(
const key_type& __k)
const;
1894 lower_bound(
const key_type& __k)
1895 {
return iterator(_M_lower_bound(_M_begin(), _M_end(), __k)); }
1898 lower_bound(
const key_type& __k)
const
1900 return const_iterator
1901 (_M_lower_bound(_M_begin(), _M_end(), __k));
1905 upper_bound(
const key_type& __k)
1906 {
return iterator(_M_upper_bound(_M_begin(), _M_end(), __k)); }
1909 upper_bound(
const key_type& __k)
const
1911 return const_iterator
1912 (_M_upper_bound(_M_begin(), _M_end(), __k));
1916 equal_range(
const key_type& __k);
1919 equal_range(
const key_type& __k)
const;
1921#if __cplusplus >= 201402L
1922 template<
typename _Kt,
1923 typename _Req = __has_is_transparent_t<_Compare, _Kt>>
1925 _M_find_tr(
const _Kt& __k)
1927 const _Rb_tree* __const_this =
this;
1928 return iterator(__const_this->_M_find_tr(__k)._M_node);
1931 template<
typename _Kt,
1932 typename _Req = __has_is_transparent_t<_Compare, _Kt>>
1934 _M_find_tr(
const _Kt& __k)
const
1936 const_iterator __j(_M_lower_bound_tr(__k));
1937 if (__j != end() && _M_key_compare(__k, _S_key(__j._M_node)))
1942 template<
typename _Kt,
1943 typename _Req = __has_is_transparent_t<_Compare, _Kt>>
1945 _M_count_tr(
const _Kt& __k)
const
1947 auto __p = _M_equal_range_tr(__k);
1951 template<
typename _Kt,
1952 typename _Req = __has_is_transparent_t<_Compare, _Kt>>
1954 _M_lower_bound_tr(
const _Kt& __k)
const
1956 auto __x = _M_begin();
1957 auto __y = _M_end();
1959 if (!_M_key_compare(_S_key(__x), __k))
1965 __x = _S_right(__x);
1969 template<
typename _Kt,
1970 typename _Req = __has_is_transparent_t<_Compare, _Kt>>
1972 _M_upper_bound_tr(
const _Kt& __k)
const
1974 auto __x = _M_begin();
1975 auto __y = _M_end();
1977 if (_M_key_compare(__k, _S_key(__x)))
1983 __x = _S_right(__x);
1987 template<
typename _Kt,
1988 typename _Req = __has_is_transparent_t<_Compare, _Kt>>
1990 _M_equal_range_tr(
const _Kt& __k)
1992 const _Rb_tree* __const_this =
this;
1993 auto __ret = __const_this->_M_equal_range_tr(__k);
1995 { iterator(__ret.first._M_node), iterator(__ret.second._M_node) };
1998 template<
typename _Kt,
1999 typename _Req = __has_is_transparent_t<_Compare, _Kt>>
2001 _M_equal_range_tr(
const _Kt& __k)
const
2003 const_iterator __low(_M_lower_bound_tr(__k));
2004 auto __high = __low;
2005 auto& __cmp = _M_impl._M_key_compare;
2006 while (__high != end() && !__cmp(__k, _S_key(__high._M_node)))
2008 return { __low, __high };
2014 __rb_verify()
const;
2016#if __cplusplus >= 201103L
2018 operator=(_Rb_tree&&)
2019 noexcept(_Node_alloc_traits::_S_nothrow_move()
2020 && is_nothrow_move_assignable<_Compare>::value);
2022 template<typename _Iterator>
2024 _M_assign_unique(_Iterator, _Iterator);
2026 template<typename _Iterator>
2028 _M_assign_equal(_Iterator, _Iterator);
2034 { _M_impl._M_move_data(__x._M_impl); }
2051#if __glibcxx_node_extract
2053 _S_adapt(
typename _Node_alloc_traits::pointer __ptr)
2055#if _GLIBCXX_USE_ALLOC_PTR_FOR_RB_TREE
2058#pragma GCC diagnostic push
2059#pragma GCC diagnostic ignored "-Wc++17-extensions"
2060 using __alloc_ptr =
typename _Node_alloc_traits::pointer;
2061 if constexpr (is_same<_Node_ptr, __alloc_ptr>::value)
2064 return std::__to_address(__ptr);
2065#pragma GCC diagnostic pop
2072 _M_reinsert_node_unique(node_type&& __nh)
2074 insert_return_type __ret;
2076 __ret.position = end();
2079 __glibcxx_assert(_M_get_Node_allocator() == *__nh._M_alloc);
2081 auto __res = _M_get_insert_unique_pos(__nh._M_key());
2085 = _M_insert_node(__res.first, __res.second,
2086 _S_adapt(__nh._M_ptr));
2088 __ret.inserted =
true;
2093 __ret.position = iterator(__res.first);
2094 __ret.inserted =
false;
2102 _M_reinsert_node_equal(node_type&& __nh)
2109 __glibcxx_assert(_M_get_Node_allocator() == *__nh._M_alloc);
2110 auto __res = _M_get_insert_equal_pos(__nh._M_key());
2112 __ret = _M_insert_node(__res.first, __res.second,
2113 _S_adapt(__nh._M_ptr));
2115 __ret = _M_insert_equal_lower_node(_S_adapt(__nh._M_ptr));
2123 _M_reinsert_node_hint_unique(const_iterator __hint, node_type&& __nh)
2130 __glibcxx_assert(_M_get_Node_allocator() == *__nh._M_alloc);
2131 auto __res = _M_get_insert_hint_unique_pos(__hint, __nh._M_key());
2134 __ret = _M_insert_node(__res.first, __res.second,
2135 _S_adapt(__nh._M_ptr));
2139 __ret = iterator(__res.first);
2146 _M_reinsert_node_hint_equal(const_iterator __hint, node_type&& __nh)
2153 __glibcxx_assert(_M_get_Node_allocator() == *__nh._M_alloc);
2154 auto __res = _M_get_insert_hint_equal_pos(__hint, __nh._M_key());
2156 __ret = _M_insert_node(__res.first, __res.second,
2157 _S_adapt(__nh._M_ptr));
2159 __ret = _M_insert_equal_lower_node(_S_adapt(__nh._M_ptr));
2167 extract(const_iterator __pos)
2169 auto __ptr = _Node_traits::_S_rebalance_for_erase
2170 (__pos._M_node, _M_impl._M_header);
2171 --_M_impl._M_node_count;
2172 auto __node_ptr =
static_cast<_Node&
>(*__ptr)._M_node_ptr();
2173#if _GLIBCXX_USE_ALLOC_PTR_FOR_RB_TREE
2174 return { __node_ptr, _M_get_Node_allocator() };
2176#pragma GCC diagnostic push
2177#pragma GCC diagnostic ignored "-Wc++17-extensions"
2178 using __alloc_ptr =
typename _Node_alloc_traits::pointer;
2179 if constexpr (is_same<_Node_ptr, __alloc_ptr>::value)
2180 return { __node_ptr, _M_get_Node_allocator() };
2183 auto __ap = pointer_traits<__alloc_ptr>::pointer_to(*__node_ptr);
2184 return { __ap, _M_get_Node_allocator() };
2186#pragma GCC diagnostic pop
2192 extract(
const key_type& __k)
2195 auto __pos = find(__k);
2197 __nh = extract(const_iterator(__pos));
2201 template<
typename _Compare2>
2202 using _Compatible_tree
2203 = _Rb_tree<_Key, _Val, _KeyOfValue, _Compare2, _Alloc>;
2205 template<
typename,
typename>
2206 friend struct _Rb_tree_merge_helper;
2209 template<
typename _Compare2>
2211 _M_merge_unique(_Compatible_tree<_Compare2>& __src)
noexcept
2213 using _Merge_helper = _Rb_tree_merge_helper<_Rb_tree, _Compare2>;
2214 for (
auto __i = __src.begin(), __end = __src.end(); __i != __end;)
2217 auto __res = _M_get_insert_unique_pos(_KeyOfValue()(*__pos));
2220 auto& __src_impl = _Merge_helper::_S_get_impl(__src);
2221 auto __ptr = _Node_traits::_S_rebalance_for_erase
2222 (__pos._M_node, __src_impl._M_header);
2223 --__src_impl._M_node_count;
2224 auto __node_ptr =
static_cast<_Node&
>(*__ptr)._M_node_ptr();
2225 _M_insert_node(__res.first, __res.second, __node_ptr);
2231 template<
typename _Compare2>
2233 _M_merge_equal(_Compatible_tree<_Compare2>& __src)
noexcept
2235 using _Merge_helper = _Rb_tree_merge_helper<_Rb_tree, _Compare2>;
2236 for (
auto __i = __src.begin(), __end = __src.end(); __i != __end;)
2239 auto __res = _M_get_insert_equal_pos(_KeyOfValue()(*__pos));
2242 auto& __src_impl = _Merge_helper::_S_get_impl(__src);
2243 auto __ptr = _Node_traits::_S_rebalance_for_erase
2244 (__pos._M_node, __src_impl._M_header);
2245 --__src_impl._M_node_count;
2246 auto __node_ptr =
static_cast<_Node&
>(*__ptr)._M_node_ptr();
2247 _M_insert_node(__res.first, __res.second, __node_ptr);
2254 operator==(
const _Rb_tree& __x,
const _Rb_tree& __y)
2256 return __x.size() == __y.size()
2257 && std::equal(__x.begin(), __x.end(), __y.begin());
2260#if __cpp_lib_three_way_comparison
2262 operator<=>(
const _Rb_tree& __x,
const _Rb_tree& __y)
2264 if constexpr (
requires {
typename __detail::__synth3way_t<_Val>; })
2266 __y.begin(), __y.end(),
2267 __detail::__synth3way);
2271 operator<(
const _Rb_tree& __x,
const _Rb_tree& __y)
2273 return std::lexicographical_compare(__x.begin(), __x.end(),
2274 __y.begin(), __y.end());
2279#if __cplusplus >= 201103L
2283 template<
typename... _Args>
2284 _Auto_node(_Rb_tree& __t, _Args&&... __args)
2286 _M_node(__t._M_create_node(std::
forward<_Args>(__args)...))
2292 _M_t._M_drop_node(_M_node);
2295 _Auto_node(_Auto_node&& __n)
2296 : _M_t(__n._M_t), _M_node(__n._M_node)
2297 { __n._M_node =
nullptr; }
2301 {
return _S_key(_M_node); }
2306 auto __it = _M_t._M_insert_node(__p.first, __p.second, _M_node);
2312 _M_insert_equal_lower()
2314 auto __it = _M_t._M_insert_equal_lower_node(_M_node);
2325 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2326 typename _Compare,
typename _Alloc>
2328 swap(_Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>& __x,
2329 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>& __y)
2332#if __cplusplus >= 201103L
2333 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2334 typename _Compare,
typename _Alloc>
2336 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2339 if (_M_get_Node_allocator() == __x._M_get_Node_allocator())
2343 constexpr bool __move = !__move_if_noexcept_cond<value_type>::value;
2344 _Alloc_node __an(*
this);
2345 _M_root() = _M_copy<__move>(__x, __an);
2346#pragma GCC diagnostic push
2347#pragma GCC diagnostic ignored "-Wc++17-extensions"
2348 if constexpr (__move)
2350#pragma GCC diagnostic pop
2354 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2355 typename _Compare,
typename _Alloc>
2357 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2358 _M_move_assign(_Rb_tree& __x,
true_type)
2363 std::__alloc_on_move(_M_get_Node_allocator(),
2364 __x._M_get_Node_allocator());
2367 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2368 typename _Compare,
typename _Alloc>
2370 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2373 if (_M_get_Node_allocator() == __x._M_get_Node_allocator())
2374 return _M_move_assign(__x,
true_type{});
2378 _Reuse_or_alloc_node __roan(*
this);
2382 _M_root() = _M_copy<__as_rvalue>(__x, __roan);
2387 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2388 typename _Compare,
typename _Alloc>
2389 inline _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>&
2390 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2391 operator=(_Rb_tree&& __x)
2392 noexcept(_Node_alloc_traits::_S_nothrow_move()
2395 _M_impl._M_key_compare =
std::move(__x._M_impl._M_key_compare);
2397 __bool_constant<_Node_alloc_traits::_S_nothrow_move()>());
2401 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2402 typename _Compare,
typename _Alloc>
2403 template<
typename _Iterator>
2405 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2406 _M_assign_unique(_Iterator __first, _Iterator __last)
2408 _Reuse_or_alloc_node __roan(*
this);
2410 for (; __first != __last; ++__first)
2411 _M_insert_unique_(
end(), *__first, __roan);
2414 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2415 typename _Compare,
typename _Alloc>
2416 template<
typename _Iterator>
2418 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2419 _M_assign_equal(_Iterator __first, _Iterator __last)
2421 _Reuse_or_alloc_node __roan(*
this);
2423 for (; __first != __last; ++__first)
2424 _M_insert_equal_(
end(), *__first, __roan);
2428 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2429 typename _Compare,
typename _Alloc>
2430 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>&
2431 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2432 operator=(
const _Rb_tree& __x)
2437#if __cplusplus >= 201103L
2438 if (_Node_alloc_traits::_S_propagate_on_copy_assign())
2440 auto& __this_alloc = this->_M_get_Node_allocator();
2441 auto& __that_alloc = __x._M_get_Node_allocator();
2442 if (!_Node_alloc_traits::_S_always_equal()
2443 && __this_alloc != __that_alloc)
2448 std::__alloc_on_copy(__this_alloc, __that_alloc);
2453 _Reuse_or_alloc_node __roan(*
this);
2455 _M_impl._M_key_compare = __x._M_impl._M_key_compare;
2457 _M_root() = _M_copy<__as_lvalue>(__x, __roan);
2463 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2464 typename _Compare,
typename _Alloc>
2465#if __cplusplus >= 201103L
2466 template<
typename _Arg,
typename _NodeGen>
2468 template<
typename _NodeGen>
2470 typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::iterator
2471 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2472 _M_insert_(_Base_ptr __x, _Base_ptr __p,
2473#
if __cplusplus >= 201103L
2478 _NodeGen& __node_gen)
2480 bool __insert_left = (__x || __p == _M_end()
2481 || _M_key_compare(_KeyOfValue()(__v),
2485 __node_gen(_GLIBCXX_FORWARD(_Arg, __v))->_M_base_ptr();
2487 _Node_traits::_S_insert_and_rebalance
2488 (__insert_left, __z, __p, this->_M_impl._M_header);
2489 ++_M_impl._M_node_count;
2493 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2494 typename _Compare,
typename _Alloc>
2495#if __cplusplus >= 201103L
2496 template<
typename _Arg>
2498 typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::iterator
2499 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2500#if __cplusplus >= 201103L
2501 _M_insert_lower(_Base_ptr __p, _Arg&& __v)
2503 _M_insert_lower(_Base_ptr __p,
const _Val& __v)
2506 bool __insert_left = (__p == _M_end()
2507 || !_M_key_compare(_S_key(__p),
2508 _KeyOfValue()(__v)));
2511 _M_create_node(_GLIBCXX_FORWARD(_Arg, __v))->_M_base_ptr();
2512 _Node_traits::_S_insert_and_rebalance
2513 (__insert_left, __z, __p, this->_M_impl._M_header);
2514 ++_M_impl._M_node_count;
2518 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2519 typename _Compare,
typename _Alloc>
2520#if __cplusplus >= 201103L
2521 template<
typename _Arg>
2523 typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::iterator
2524 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2525#if __cplusplus >= 201103L
2526 _M_insert_equal_lower(_Arg&& __v)
2528 _M_insert_equal_lower(
const _Val& __v)
2531 _Base_ptr __x = _M_begin();
2532 _Base_ptr __y = _M_end();
2536 __x = !_M_key_compare(_S_key(__x), _KeyOfValue()(__v)) ?
2537 _S_left(__x) : _S_right(__x);
2539 return _M_insert_lower(__y, _GLIBCXX_FORWARD(_Arg, __v));
2542 template<
typename _Key,
typename _Val,
typename _KoV,
2543 typename _Compare,
typename _Alloc>
2544 template<
bool _MoveValues,
typename _NodeGen>
2545 typename _Rb_tree<_Key, _Val, _KoV, _Compare, _Alloc>::_Base_ptr
2546 _Rb_tree<_Key, _Val, _KoV, _Compare, _Alloc>::
2547 _M_copy(_Node_ptr __x, _Base_ptr __p, _NodeGen& __node_gen)
2550 _Node_ptr __top = _M_clone_node<_MoveValues>(__x, __node_gen);
2551 _Base_ptr __top_base = __top->_M_base_ptr();
2552 __top->_M_parent = __p;
2558 _M_copy<_MoveValues>(_S_right(__x), __top_base, __node_gen);
2565 _M_clone_node<_MoveValues>(__x, __node_gen)->_M_base_ptr();
2567 __y->_M_parent = __p;
2569 __y->_M_right = _M_copy<_MoveValues>(_S_right(__x),
2578 __throw_exception_again;
2583 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2584 typename _Compare,
typename _Alloc>
2586 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2587 _M_erase(_Node_ptr __x)
2592 _M_erase(_S_right(__x));
2593 _Node_ptr __y = _S_left(__x);
2599 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2600 typename _Compare,
typename _Alloc>
2601 typename _Rb_tree<_Key, _Val, _KeyOfValue,
2602 _Compare, _Alloc>::_Base_ptr
2603 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2604 _M_lower_bound(_Base_ptr __x, _Base_ptr __y,
2605 const _Key& __k)
const
2608 if (!_M_key_compare(_S_key(__x), __k))
2609 __y = __x, __x = _S_left(__x);
2611 __x = _S_right(__x);
2615 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2616 typename _Compare,
typename _Alloc>
2617 typename _Rb_tree<_Key, _Val, _KeyOfValue,
2618 _Compare, _Alloc>::_Base_ptr
2619 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2620 _M_upper_bound(_Base_ptr __x, _Base_ptr __y,
2621 const _Key& __k)
const
2624 if (_M_key_compare(__k, _S_key(__x)))
2625 __y = __x, __x = _S_left(__x);
2627 __x = _S_right(__x);
2631 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2632 typename _Compare,
typename _Alloc>
2633 pair<
typename _Rb_tree<_Key, _Val, _KeyOfValue,
2634 _Compare, _Alloc>::iterator,
2635 typename _Rb_tree<_Key, _Val, _KeyOfValue,
2636 _Compare, _Alloc>::iterator>
2637 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2638 equal_range(
const _Key& __k)
2642 _Base_ptr __x = _M_begin();
2643 _Base_ptr __y = _M_end();
2646 if (_M_key_compare(_S_key(__x), __k))
2647 __x = _S_right(__x);
2648 else if (_M_key_compare(__k, _S_key(__x)))
2649 __y = __x, __x = _S_left(__x);
2652 _Base_ptr __xu(__x);
2653 _Base_ptr __yu(__y);
2654 __y = __x, __x = _S_left(__x);
2655 __xu = _S_right(__xu);
2656 return _Ret(
iterator(_M_lower_bound(__x, __y, __k)),
2657 iterator(_M_upper_bound(__xu, __yu, __k)));
2663 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2664 typename _Compare,
typename _Alloc>
2665 pair<
typename _Rb_tree<_Key, _Val, _KeyOfValue,
2666 _Compare, _Alloc>::const_iterator,
2667 typename _Rb_tree<_Key, _Val, _KeyOfValue,
2668 _Compare, _Alloc>::const_iterator>
2669 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2670 equal_range(
const _Key& __k)
const
2674 _Base_ptr __x = _M_begin();
2675 _Base_ptr __y = _M_end();
2678 if (_M_key_compare(_S_key(__x), __k))
2679 __x = _S_right(__x);
2680 else if (_M_key_compare(__k, _S_key(__x)))
2681 __y = __x, __x = _S_left(__x);
2684 _Base_ptr __xu(__x);
2685 _Base_ptr __yu(__y);
2686 __y = __x, __x = _S_left(__x);
2687 __xu = _S_right(__xu);
2688 return _Ret(const_iterator(_M_lower_bound(__x, __y, __k)),
2689 const_iterator(_M_upper_bound(__xu, __yu, __k)));
2692 return _Ret(const_iterator(__y), const_iterator(__y));
2695 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2696 typename _Compare,
typename _Alloc>
2698 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2700 _GLIBCXX_NOEXCEPT_IF(__is_nothrow_swappable<_Compare>::value)
2705 _M_impl._M_move_data(__t._M_impl);
2707 else if (!__t._M_root())
2708 __t._M_impl._M_move_data(_M_impl);
2711 std::swap(_M_root(),__t._M_root());
2712 std::swap(_M_leftmost(),__t._M_leftmost());
2713 std::swap(_M_rightmost(),__t._M_rightmost());
2715 _M_root()->_M_parent = _M_end();
2716 __t._M_root()->_M_parent = __t._M_end();
2717 std::swap(this->_M_impl._M_node_count, __t._M_impl._M_node_count);
2722 swap(this->_M_impl._M_key_compare, __t._M_impl._M_key_compare);
2724 _Node_alloc_traits::_S_on_swap(_M_get_Node_allocator(),
2725 __t._M_get_Node_allocator());
2728 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2729 typename _Compare,
typename _Alloc>
2730 pair<
typename _Rb_tree<_Key, _Val, _KeyOfValue,
2731 _Compare, _Alloc>::_Base_ptr,
2732 typename _Rb_tree<_Key, _Val, _KeyOfValue,
2733 _Compare, _Alloc>::_Base_ptr>
2734 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2735 _M_get_insert_unique_pos(
const key_type& __k)
2738 _Base_ptr __x = _M_begin();
2739 _Base_ptr __y = _M_end();
2744 __comp = _M_key_compare(__k, _S_key(__x));
2745 __x = __comp ? _S_left(__x) : _S_right(__x);
2751 return _Res(__x, __y);
2755 if (_M_key_compare(_S_key(__j._M_node), __k))
2756 return _Res(__x, __y);
2757 return _Res(__j._M_node, _Base_ptr());
2760 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2761 typename _Compare,
typename _Alloc>
2762 pair<
typename _Rb_tree<_Key, _Val, _KeyOfValue,
2763 _Compare, _Alloc>::_Base_ptr,
2764 typename _Rb_tree<_Key, _Val, _KeyOfValue,
2765 _Compare, _Alloc>::_Base_ptr>
2766 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2767 _M_get_insert_equal_pos(
const key_type& __k)
2770 _Base_ptr __x = _M_begin();
2771 _Base_ptr __y = _M_end();
2775 __x = _M_key_compare(__k, _S_key(__x)) ? _S_left(__x) : _S_right(__x);
2777 return _Res(__x, __y);
2780 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2781 typename _Compare,
typename _Alloc>
2782#if __cplusplus >= 201103L
2783 template<
typename _Arg>
2785 pair<
typename _Rb_tree<_Key, _Val, _KeyOfValue,
2786 _Compare, _Alloc>::iterator,
bool>
2787 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2788#if __cplusplus >= 201103L
2789 _M_insert_unique(_Arg&& __v)
2791 _M_insert_unique(
const _Val& __v)
2796 = _M_get_insert_unique_pos(_KeyOfValue()(__v));
2800 _Alloc_node __an(*
this);
2801 return _Res(_M_insert_(__res.first, __res.second,
2802 _GLIBCXX_FORWARD(_Arg, __v), __an),
2806 return _Res(
iterator(__res.first),
false);
2809 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2810 typename _Compare,
typename _Alloc>
2811#if __cplusplus >= 201103L
2812 template<
typename _Arg>
2814 typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::iterator
2815 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2816#if __cplusplus >= 201103L
2817 _M_insert_equal(_Arg&& __v)
2819 _M_insert_equal(
const _Val& __v)
2823 = _M_get_insert_equal_pos(_KeyOfValue()(__v));
2824 _Alloc_node __an(*
this);
2825 return _M_insert_(__res.first, __res.second,
2826 _GLIBCXX_FORWARD(_Arg, __v), __an);
2829 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2830 typename _Compare,
typename _Alloc>
2831 pair<
typename _Rb_tree<_Key, _Val, _KeyOfValue,
2832 _Compare, _Alloc>::_Base_ptr,
2833 typename _Rb_tree<_Key, _Val, _KeyOfValue,
2834 _Compare, _Alloc>::_Base_ptr>
2835 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2836 _M_get_insert_hint_unique_pos(const_iterator __position,
2837 const key_type& __k)
2842 if (__position._M_node == _M_end())
2844 if (
size() > 0 && _M_key_compare(_S_key(_M_rightmost()), __k))
2845 return _Res(_Base_ptr(), _M_rightmost());
2847 return _M_get_insert_unique_pos(__k);
2849 else if (_M_key_compare(__k, _S_key(__position._M_node)))
2852 iterator __before(__position._M_node);
2853 if (__position._M_node == _M_leftmost())
2854 return _Res(_M_leftmost(), _M_leftmost());
2855 else if (_M_key_compare(_S_key((--__before)._M_node), __k))
2857 if (!_S_right(__before._M_node))
2858 return _Res(_Base_ptr(), __before._M_node);
2860 return _Res(__position._M_node, __position._M_node);
2863 return _M_get_insert_unique_pos(__k);
2865 else if (_M_key_compare(_S_key(__position._M_node), __k))
2868 iterator __after(__position._M_node);
2869 if (__position._M_node == _M_rightmost())
2870 return _Res(_Base_ptr(), _M_rightmost());
2871 else if (_M_key_compare(__k, _S_key((++__after)._M_node)))
2873 if (!_S_right(__position._M_node))
2874 return _Res(_Base_ptr(), __position._M_node);
2876 return _Res(__after._M_node, __after._M_node);
2879 return _M_get_insert_unique_pos(__k);
2883 return _Res(__position._M_node, _Base_ptr());
2886 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2887 typename _Compare,
typename _Alloc>
2888#if __cplusplus >= 201103L
2889 template<
typename _Arg,
typename _NodeGen>
2891 template<
typename _NodeGen>
2893 typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::iterator
2894 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2895 _M_insert_unique_(const_iterator __position,
2896#
if __cplusplus >= 201103L
2901 _NodeGen& __node_gen)
2904 = _M_get_insert_hint_unique_pos(__position, _KeyOfValue()(__v));
2907 return _M_insert_(__res.first, __res.second,
2908 _GLIBCXX_FORWARD(_Arg, __v),
2913 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2914 typename _Compare,
typename _Alloc>
2915 pair<
typename _Rb_tree<_Key, _Val, _KeyOfValue,
2916 _Compare, _Alloc>::_Base_ptr,
2917 typename _Rb_tree<_Key, _Val, _KeyOfValue,
2918 _Compare, _Alloc>::_Base_ptr>
2919 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2920 _M_get_insert_hint_equal_pos(const_iterator __position,
const key_type& __k)
2925 if (__position._M_node == _M_end())
2928 && !_M_key_compare(__k, _S_key(_M_rightmost())))
2929 return _Res(_Base_ptr(), _M_rightmost());
2931 return _M_get_insert_equal_pos(__k);
2933 else if (!_M_key_compare(_S_key(__position._M_node), __k))
2936 iterator __before(__position._M_node);
2937 if (__position._M_node == _M_leftmost())
2938 return _Res(_M_leftmost(), _M_leftmost());
2939 else if (!_M_key_compare(__k, _S_key((--__before)._M_node)))
2941 if (!_S_right(__before._M_node))
2942 return _Res(_Base_ptr(), __before._M_node);
2944 return _Res(__position._M_node, __position._M_node);
2947 return _M_get_insert_equal_pos(__k);
2952 iterator __after(__position._M_node);
2953 if (__position._M_node == _M_rightmost())
2954 return _Res(_Base_ptr(), _M_rightmost());
2955 else if (!_M_key_compare(_S_key((++__after)._M_node), __k))
2957 if (!_S_right(__position._M_node))
2958 return _Res(_Base_ptr(), __position._M_node);
2960 return _Res(__after._M_node, __after._M_node);
2963 return _Res(_Base_ptr(), _Base_ptr());
2967 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2968 typename _Compare,
typename _Alloc>
2969#if __cplusplus >= 201103L
2970 template<
typename _Arg,
typename _NodeGen>
2972 template<
typename _NodeGen>
2974 typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::iterator
2975 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2976 _M_insert_equal_(const_iterator __position,
2977#
if __cplusplus >= 201103L
2982 _NodeGen& __node_gen)
2985 = _M_get_insert_hint_equal_pos(__position, _KeyOfValue()(__v));
2988 return _M_insert_(__res.first, __res.second,
2989 _GLIBCXX_FORWARD(_Arg, __v),
2992 return _M_insert_equal_lower(_GLIBCXX_FORWARD(_Arg, __v));
2995#if __cplusplus >= 201103L
2996 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2997 typename _Compare,
typename _Alloc>
2999 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3000 _M_insert_node(_Base_ptr __x, _Base_ptr __p, _Node_ptr __z)
3003 bool __insert_left = (__x || __p == _M_end()
3004 || _M_key_compare(_S_key(__z), _S_key(__p)));
3006 _Base_ptr __base_z = __z->_M_base_ptr();
3007 _Node_traits::_S_insert_and_rebalance
3008 (__insert_left, __base_z, __p, this->_M_impl._M_header);
3009 ++_M_impl._M_node_count;
3013 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3014 typename _Compare,
typename _Alloc>
3016 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3017 _M_insert_lower_node(_Base_ptr __p, _Node_ptr __z)
3020 bool __insert_left = (__p == _M_end()
3021 || !_M_key_compare(_S_key(__p), _S_key(__z)));
3023 _Base_ptr __base_z = __z->_M_base_ptr();
3024 _Node_traits::_S_insert_and_rebalance
3025 (__insert_left, __base_z, __p, this->_M_impl._M_header);
3026 ++_M_impl._M_node_count;
3030 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3031 typename _Compare,
typename _Alloc>
3033 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3034 _M_insert_equal_lower_node(_Node_ptr __z)
3037 _Base_ptr __x = _M_begin();
3038 _Base_ptr __y = _M_end();
3042 __x = !_M_key_compare(_S_key(__x), _S_key(__z)) ?
3043 _S_left(__x) : _S_right(__x);
3045 return _M_insert_lower_node(__y, __z);
3048 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3049 typename _Compare,
typename _Alloc>
3050 template<
typename... _Args>
3052 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3053 _M_emplace_unique(_Args&&... __args)
3057 auto __res = _M_get_insert_unique_pos(__z._M_key());
3059 return {__z._M_insert(__res),
true};
3060 return {
iterator(__res.first),
false};
3063 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3064 typename _Compare,
typename _Alloc>
3065 template<
typename... _Args>
3067 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3068 _M_emplace_equal(_Args&&... __args)
3072 auto __res = _M_get_insert_equal_pos(__z._M_key());
3073 return __z._M_insert(__res);
3076 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3077 typename _Compare,
typename _Alloc>
3078 template<
typename... _Args>
3080 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3081 _M_emplace_hint_unique(const_iterator __pos, _Args&&... __args)
3085 auto __res = _M_get_insert_hint_unique_pos(__pos, __z._M_key());
3087 return __z._M_insert(__res);
3091 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3092 typename _Compare,
typename _Alloc>
3093 template<
typename... _Args>
3095 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3096 _M_emplace_hint_equal(const_iterator __pos, _Args&&... __args)
3100 auto __res = _M_get_insert_hint_equal_pos(__pos, __z._M_key());
3102 return __z._M_insert(__res);
3103 return __z._M_insert_equal_lower();
3108 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3109 typename _Compare,
typename _Alloc>
3111 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3112 _M_erase_aux(const_iterator __position)
3114 _Base_ptr __y = _Node_traits::_S_rebalance_for_erase
3115 (__position._M_node, this->_M_impl._M_header);
3116 _M_drop_node(
static_cast<_Node&
>(*__y)._M_node_ptr());
3117 --_M_impl._M_node_count;
3120 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3121 typename _Compare,
typename _Alloc>
3123 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3124 _M_erase_aux(const_iterator __first, const_iterator __last)
3126 if (__first ==
begin() && __last ==
end())
3129 while (__first != __last)
3130 _M_erase_aux(__first++);
3133 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3134 typename _Compare,
typename _Alloc>
3135 typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::size_type
3136 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3137 erase(
const _Key& __x)
3141 _M_erase_aux(__p.first, __p.second);
3142 return __old_size -
size();
3145 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3146 typename _Compare,
typename _Alloc>
3147 typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::size_type
3148 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3149 _M_erase_unique(
const _Key& __x)
3159 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3160 typename _Compare,
typename _Alloc>
3161 typename _Rb_tree<_Key, _Val, _KeyOfValue,
3162 _Compare, _Alloc>::iterator
3163 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3164 find(
const _Key& __k)
3166 iterator __j(_M_lower_bound(_M_begin(), _M_end(), __k));
3167 return (__j ==
end()
3168 || _M_key_compare(__k, _S_key(__j._M_node))) ?
end() : __j;
3171 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3172 typename _Compare,
typename _Alloc>
3173 typename _Rb_tree<_Key, _Val, _KeyOfValue,
3174 _Compare, _Alloc>::const_iterator
3175 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3176 find(
const _Key& __k)
const
3178 const_iterator __j(_M_lower_bound(_M_begin(), _M_end(), __k));
3179 return (__j ==
end()
3180 || _M_key_compare(__k, _S_key(__j._M_node))) ?
end() : __j;
3183 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3184 typename _Compare,
typename _Alloc>
3185 typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::size_type
3186 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3187 count(
const _Key& __k)
const
3194 _GLIBCXX_PURE
unsigned int
3195 _Rb_tree_black_count(
const _Rb_tree_node_base* __node,
3196 const _Rb_tree_node_base* __root)
throw ();
3198 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3199 typename _Compare,
typename _Alloc>
3201 _Rb_tree<_Key,_Val,_KeyOfValue,_Compare,_Alloc>::__rb_verify()
const
3203 if (_M_impl._M_node_count == 0 ||
begin() ==
end())
3204 return _M_impl._M_node_count == 0 &&
begin() ==
end()
3205 && this->_M_impl._M_header._M_left == _M_end()
3206 && this->_M_impl._M_header._M_right == _M_end();
3208 unsigned int __len = _Rb_tree_black_count(_M_leftmost(), _M_root());
3209 for (const_iterator __it =
begin(); __it !=
end(); ++__it)
3211 _Base_ptr __x = __it._M_node;
3212 _Base_ptr __L = _S_left(__x);
3213 _Base_ptr __R = _S_right(__x);
3215 if (__x->_M_color == _S_red)
3216 if ((__L && __L->_M_color == _S_red)
3217 || (__R && __R->_M_color == _S_red))
3220 if (__L && _M_key_compare(_S_key(__x), _S_key(__L)))
3222 if (__R && _M_key_compare(_S_key(__R), _S_key(__x)))
3225 if (!__L && !__R && _Rb_tree_black_count(__x, _M_root()) != __len)
3229 if (_M_leftmost() != _Node_base::_S_minimum(_M_root()))
3231 if (_M_rightmost() != _Node_base::_S_maximum(_M_root()))
3236#ifdef __glibcxx_node_extract
3238 template<
typename _Key,
typename _Val,
typename _Sel,
typename _Cmp1,
3239 typename _Alloc,
typename _Cmp2>
3240 struct _Rb_tree_merge_helper<_Rb_tree<_Key, _Val, _Sel, _Cmp1, _Alloc>,
3244 friend class _Rb_tree<_Key, _Val, _Sel, _Cmp1, _Alloc>;
3247 _S_get_impl(_Rb_tree<_Key, _Val, _Sel, _Cmp2, _Alloc>& __tree)
3248 {
return __tree._M_impl; }
3252_GLIBCXX_END_NAMESPACE_VERSION
constexpr bool operator<(const duration< _Rep1, _Period1 > &__lhs, const duration< _Rep2, _Period2 > &__rhs)
__bool_constant< true > true_type
The type used as a compile-time boolean with true value.
__bool_constant< false > false_type
The type used as a compile-time boolean with false value.
pair(_T1, _T2) -> pair< _T1, _T2 >
Two pairs are equal iff their members are equal.
auto declval() noexcept -> decltype(__declval< _Tp >(0))
constexpr _Tp * addressof(_Tp &__r) noexcept
Returns the actual address of the object or function referenced by r, even in the presence of an over...
constexpr std::remove_reference< _Tp >::type && move(_Tp &&__t) noexcept
Convert a value to an rvalue.
constexpr _Tp * __addressof(_Tp &__r) noexcept
Same as C++11 std::addressof.
constexpr _Tp && forward(typename std::remove_reference< _Tp >::type &__t) noexcept
Forward an lvalue.
_Tp * end(valarray< _Tp > &__va) noexcept
Return an iterator pointing to one past the last element of the valarray.
_Tp * begin(valarray< _Tp > &__va) noexcept
Return an iterator pointing to the first element of the valarray.
constexpr auto lexicographical_compare_three_way(_InputIter1 __first1, _InputIter1 __last1, _InputIter2 __first2, _InputIter2 __last2, _Comp __comp) -> decltype(__comp(*__first1, *__first2))
Performs dictionary comparison on ranges.
ISO C++ entities toplevel namespace is std.
constexpr iterator_traits< _InputIterator >::difference_type distance(_InputIterator __first, _InputIterator __last)
A generalization of pointer arithmetic.
typename pointer_traits< _Ptr >::template rebind< _Tp > __ptr_rebind
Convenience alias for rebinding pointers.
constexpr auto size(const _Container &__cont) noexcept(noexcept(__cont.size())) -> decltype(__cont.size())
Return the size of a container.
constexpr _Iterator __base(_Iterator __it)
is_nothrow_move_assignable
The standard allocator, as per C++03 [20.4.1].
Struct holding two objects of arbitrary type.
static constexpr pointer allocate(_Node_allocator &__a, size_type __n)
static constexpr void deallocate(_Node_allocator &__a, pointer __p, size_type __n)
static constexpr size_type max_size(const _Node_allocator &__a) noexcept