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 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;
1542 template <
typename _Kt>
1544 _M_lower_bound_tr(_Base_ptr __x, _Base_ptr __y,
const _Kt& __k)
const;
1547 _M_upper_bound(_Base_ptr __x, _Base_ptr __y,
1548 const _Key& __k)
const;
1550 template <
typename _Kt>
1552 _M_upper_bound_tr(_Base_ptr __x, _Base_ptr __y,
const _Kt& __k)
const;
1556#if __cplusplus < 201103L
1559 _Rb_tree() =
default;
1562 _Rb_tree(
const _Compare& __comp,
1563 const allocator_type& __a = allocator_type())
1564 : _M_impl(__comp, _Node_allocator(__a)) { }
1566 _Rb_tree(
const _Rb_tree& __x)
1567 : _M_impl(__x._M_impl)
1570 _M_root() = _M_copy(__x);
1573#if __cplusplus >= 201103L
1574 _Rb_tree(
const allocator_type& __a)
1575 : _M_impl(_Node_allocator(__a))
1578 _Rb_tree(
const _Rb_tree& __x,
const allocator_type& __a)
1579 : _M_impl(__x._M_impl._M_key_compare, _Node_allocator(__a))
1582 _M_root() = _M_copy(__x);
1585 _Rb_tree(_Rb_tree&&) =
default;
1587 _Rb_tree(_Rb_tree&& __x,
const allocator_type& __a)
1588 : _Rb_tree(std::
move(__x), _Node_allocator(__a))
1592 _Rb_tree(_Rb_tree&& __x, _Node_allocator&& __a,
true_type)
1593 noexcept(is_nothrow_default_constructible<_Compare>::value)
1594 : _M_impl(std::
move(__x._M_impl), std::
move(__a))
1597 _Rb_tree(_Rb_tree&& __x, _Node_allocator&& __a,
false_type)
1598 : _M_impl(__x._M_impl._M_key_compare, std::
move(__a))
1605 _Rb_tree(_Rb_tree&& __x, _Node_allocator&& __a)
1609 : _Rb_tree(std::
move(__x), std::
move(__a),
1610 typename _Node_alloc_traits::is_always_equal{})
1614 ~_Rb_tree() _GLIBCXX_NOEXCEPT
1615 { _M_erase(_M_begin_node()); }
1618 operator=(
const _Rb_tree& __x);
1623 {
return _M_impl._M_key_compare; }
1626 begin() _GLIBCXX_NOEXCEPT
1627 {
return iterator(this->_M_impl._M_header._M_left); }
1630 begin() const _GLIBCXX_NOEXCEPT
1631 {
return const_iterator(this->_M_impl._M_header._M_left); }
1634 end() _GLIBCXX_NOEXCEPT
1635 {
return iterator(_M_end()); }
1638 end() const _GLIBCXX_NOEXCEPT
1639 {
return const_iterator(_M_end()); }
1642 rbegin() _GLIBCXX_NOEXCEPT
1643 {
return reverse_iterator(end()); }
1645 const_reverse_iterator
1646 rbegin() const _GLIBCXX_NOEXCEPT
1647 {
return const_reverse_iterator(end()); }
1650 rend() _GLIBCXX_NOEXCEPT
1651 {
return reverse_iterator(begin()); }
1653 const_reverse_iterator
1654 rend() const _GLIBCXX_NOEXCEPT
1655 {
return const_reverse_iterator(begin()); }
1657 _GLIBCXX_NODISCARD
bool
1658 empty() const _GLIBCXX_NOEXCEPT
1659 {
return _M_impl._M_node_count == 0; }
1662 size() const _GLIBCXX_NOEXCEPT
1663 {
return _M_impl._M_node_count; }
1666 max_size() const _GLIBCXX_NOEXCEPT
1671 _GLIBCXX_NOEXCEPT_IF(__is_nothrow_swappable<_Compare>::value);
1674#if __cplusplus >= 201103L
1675 template<
typename _Arg>
1677 _M_insert_unique(_Arg&& __x);
1679 template<
typename _Arg>
1681 _M_insert_equal(_Arg&& __x);
1683 template<
typename _Arg,
typename _NodeGen>
1685 _M_insert_unique_(const_iterator __pos, _Arg&& __x, _NodeGen&);
1687 template<
typename _Arg>
1689 _M_insert_unique_(const_iterator __pos, _Arg&& __x)
1691 _Alloc_node __an(*
this);
1695 template<
typename _Arg,
typename _NodeGen>
1697 _M_insert_equal_(const_iterator __pos, _Arg&& __x, _NodeGen&);
1699 template<
typename _Arg>
1701 _M_insert_equal_(const_iterator __pos, _Arg&& __x)
1703 _Alloc_node __an(*
this);
1707 template<
typename... _Args>
1709 _M_emplace_unique(_Args&&... __args);
1711 template<
typename... _Args>
1713 _M_emplace_equal(_Args&&... __args);
1715 template<
typename... _Args>
1717 _M_emplace_hint_unique(const_iterator __pos, _Args&&... __args);
1719 template<
typename... _Args>
1721 _M_emplace_hint_equal(const_iterator __pos, _Args&&... __args);
1723 template<
typename _Iter>
1724 using __same_value_type
1725 = is_same<value_type, typename iterator_traits<_Iter>::value_type>;
1727 template<
typename _InputIterator>
1728 __enable_if_t<__same_value_type<_InputIterator>::value>
1729 _M_insert_range_unique(_InputIterator __first, _InputIterator __last)
1731 _Alloc_node __an(*
this);
1732 for (; __first != __last; ++__first)
1733 _M_insert_unique_(end(), *__first, __an);
1736 template<
typename _InputIterator>
1737 __enable_if_t<!__same_value_type<_InputIterator>::value>
1738 _M_insert_range_unique(_InputIterator __first, _InputIterator __last)
1740 for (; __first != __last; ++__first)
1741 _M_emplace_unique(*__first);
1744 template<
typename _InputIterator>
1745 __enable_if_t<__same_value_type<_InputIterator>::value>
1746 _M_insert_range_equal(_InputIterator __first, _InputIterator __last)
1748 _Alloc_node __an(*
this);
1749 for (; __first != __last; ++__first)
1750 _M_insert_equal_(end(), *__first, __an);
1753 template<
typename _InputIterator>
1754 __enable_if_t<!__same_value_type<_InputIterator>::value>
1755 _M_insert_range_equal(_InputIterator __first, _InputIterator __last)
1757 for (; __first != __last; ++__first)
1758 _M_emplace_equal(*__first);
1762 _M_insert_unique(
const value_type& __x);
1765 _M_insert_equal(
const value_type& __x);
1767 template<
typename _NodeGen>
1769 _M_insert_unique_(const_iterator __pos,
const value_type& __x,
1773 _M_insert_unique_(const_iterator __pos,
const value_type& __x)
1775 _Alloc_node __an(*
this);
1776 return _M_insert_unique_(__pos, __x, __an);
1779 template<
typename _NodeGen>
1781 _M_insert_equal_(const_iterator __pos,
const value_type& __x,
1784 _M_insert_equal_(const_iterator __pos,
const value_type& __x)
1786 _Alloc_node __an(*
this);
1787 return _M_insert_equal_(__pos, __x, __an);
1790 template<
typename _InputIterator>
1792 _M_insert_range_unique(_InputIterator __first, _InputIterator __last)
1794 _Alloc_node __an(*
this);
1795 for (; __first != __last; ++__first)
1796 _M_insert_unique_(end(), *__first, __an);
1799 template<
typename _InputIterator>
1801 _M_insert_range_equal(_InputIterator __first, _InputIterator __last)
1803 _Alloc_node __an(*
this);
1804 for (; __first != __last; ++__first)
1805 _M_insert_equal_(end(), *__first, __an);
1811 _M_erase_aux(const_iterator __position);
1814 _M_erase_aux(const_iterator __first, const_iterator __last);
1817#if __cplusplus >= 201103L
1820 _GLIBCXX_ABI_TAG_CXX11
1822 erase(const_iterator __position)
1824 __glibcxx_assert(__position != end());
1825 const_iterator __result = __position;
1827 _M_erase_aux(__position);
1828 return iterator(__result._M_node);
1832 _GLIBCXX_ABI_TAG_CXX11
1834 erase(iterator __position)
1836 __glibcxx_assert(__position != end());
1837 iterator __result = __position;
1839 _M_erase_aux(__position);
1844 erase(iterator __position)
1846 __glibcxx_assert(__position != end());
1847 _M_erase_aux(__position);
1851 erase(const_iterator __position)
1853 __glibcxx_assert(__position != end());
1854 _M_erase_aux(__position);
1859 erase(
const key_type& __x);
1861 template <
typename _Kt>
1863 _M_erase_tr(
const _Kt& __x);
1866 _M_erase_unique(
const key_type& __x);
1868#if __cplusplus >= 201103L
1871 _GLIBCXX_ABI_TAG_CXX11
1873 erase(const_iterator __first, const_iterator __last)
1875 _M_erase_aux(__first, __last);
1876 return iterator(__last._M_node);
1880 erase(iterator __first, iterator __last)
1881 { _M_erase_aux(__first, __last); }
1884 erase(const_iterator __first, const_iterator __last)
1885 { _M_erase_aux(__first, __last); }
1889 clear() _GLIBCXX_NOEXCEPT
1891 _M_erase(_M_begin_node());
1897 find(
const key_type& __k);
1900 find(
const key_type& __k)
const;
1903 count(
const key_type& __k)
const;
1906 lower_bound(
const key_type& __k)
1907 {
return iterator(_M_lower_bound(_M_begin(), _M_end(), __k)); }
1910 lower_bound(
const key_type& __k)
const
1912 return const_iterator
1913 (_M_lower_bound(_M_begin(), _M_end(), __k));
1917 upper_bound(
const key_type& __k)
1918 {
return iterator(_M_upper_bound(_M_begin(), _M_end(), __k)); }
1921 upper_bound(
const key_type& __k)
const
1923 return const_iterator
1924 (_M_upper_bound(_M_begin(), _M_end(), __k));
1928 equal_range(
const key_type& __k);
1931 equal_range(
const key_type& __k)
const;
1933#ifdef __glibcxx_generic_associative_lookup
1934 template<
typename _Kt,
1935 typename _Req = __has_is_transparent_t<_Compare, _Kt>>
1937 _M_find_tr(
const _Kt& __k)
1939 const _Rb_tree* __const_this =
this;
1940 return iterator(__const_this->_M_find_tr(__k)._M_node);
1943 template<
typename _Kt,
1944 typename _Req = __has_is_transparent_t<_Compare, _Kt>>
1946 _M_find_tr(
const _Kt& __k)
const
1948 const_iterator __j(_M_lower_bound_tr(__k));
1949 if (__j != end() && _M_key_compare(__k, _S_key(__j._M_node)))
1954 template<
typename _Kt,
1955 typename _Req = __has_is_transparent_t<_Compare, _Kt>>
1957 _M_count_tr(
const _Kt& __k)
const
1959 auto __p = _M_equal_range_tr(__k);
1963 template<
typename _Kt,
1964 typename _Req = __has_is_transparent_t<_Compare, _Kt>>
1966 _M_lower_bound_tr(
const _Kt& __k)
const
1968 auto __x = _M_begin();
1969 auto __y = _M_end();
1971 if (!_M_key_compare(_S_key(__x), __k))
1977 __x = _S_right(__x);
1981 template<
typename _Kt,
1982 typename _Req = __has_is_transparent_t<_Compare, _Kt>>
1984 _M_upper_bound_tr(
const _Kt& __k)
const
1986 auto __x = _M_begin();
1987 auto __y = _M_end();
1989 if (_M_key_compare(__k, _S_key(__x)))
1995 __x = _S_right(__x);
1999 template<
typename _Kt,
2000 typename _Req = __has_is_transparent_t<_Compare, _Kt>>
2002 _M_equal_range_tr(
const _Kt& __k)
2004 const _Rb_tree* __const_this =
this;
2005 auto __ret = __const_this->_M_equal_range_tr(__k);
2007 { iterator(__ret.first._M_node), iterator(__ret.second._M_node) };
2010 template<
typename _Kt,
2011 typename _Req = __has_is_transparent_t<_Compare, _Kt>>
2013 _M_equal_range_tr(
const _Kt& __k)
const
2015 const_iterator __low(_M_lower_bound_tr(__k));
2016 auto __high = __low;
2017 auto& __cmp = _M_impl._M_key_compare;
2018 while (__high != end() && !__cmp(__k, _S_key(__high._M_node)))
2020 return { __low, __high };
2026 __rb_verify()
const;
2028#if __cplusplus >= 201103L
2030 operator=(_Rb_tree&&)
2031 noexcept(_Node_alloc_traits::_S_nothrow_move()
2032 && is_nothrow_move_assignable<_Compare>::value);
2034 template<typename _Iterator>
2036 _M_assign_unique(_Iterator, _Iterator);
2038 template<typename _Iterator>
2040 _M_assign_equal(_Iterator, _Iterator);
2046 { _M_impl._M_move_data(__x._M_impl); }
2063#if __glibcxx_node_extract
2065 _S_adapt(
typename _Node_alloc_traits::pointer __ptr)
2067#if _GLIBCXX_USE_ALLOC_PTR_FOR_RB_TREE
2070#pragma GCC diagnostic push
2071#pragma GCC diagnostic ignored "-Wc++17-extensions"
2072 using __alloc_ptr =
typename _Node_alloc_traits::pointer;
2073 if constexpr (is_same<_Node_ptr, __alloc_ptr>::value)
2076 return std::__to_address(__ptr);
2077#pragma GCC diagnostic pop
2084 _M_reinsert_node_unique(node_type&& __nh)
2086 insert_return_type __ret;
2088 __ret.position = end();
2091 __glibcxx_assert(_M_get_Node_allocator() == *__nh._M_alloc);
2093 auto __res = _M_get_insert_unique_pos(__nh._M_key());
2097 = _M_insert_node(__res.first, __res.second,
2098 _S_adapt(__nh._M_ptr));
2100 __ret.inserted =
true;
2105 __ret.position = iterator(__res.first);
2106 __ret.inserted =
false;
2114 _M_reinsert_node_equal(node_type&& __nh)
2121 __glibcxx_assert(_M_get_Node_allocator() == *__nh._M_alloc);
2122 auto __res = _M_get_insert_equal_pos(__nh._M_key());
2124 __ret = _M_insert_node(__res.first, __res.second,
2125 _S_adapt(__nh._M_ptr));
2127 __ret = _M_insert_equal_lower_node(_S_adapt(__nh._M_ptr));
2135 _M_reinsert_node_hint_unique(const_iterator __hint, node_type&& __nh)
2142 __glibcxx_assert(_M_get_Node_allocator() == *__nh._M_alloc);
2143 auto __res = _M_get_insert_hint_unique_pos(__hint, __nh._M_key());
2146 __ret = _M_insert_node(__res.first, __res.second,
2147 _S_adapt(__nh._M_ptr));
2151 __ret = iterator(__res.first);
2158 _M_reinsert_node_hint_equal(const_iterator __hint, node_type&& __nh)
2165 __glibcxx_assert(_M_get_Node_allocator() == *__nh._M_alloc);
2166 auto __res = _M_get_insert_hint_equal_pos(__hint, __nh._M_key());
2168 __ret = _M_insert_node(__res.first, __res.second,
2169 _S_adapt(__nh._M_ptr));
2171 __ret = _M_insert_equal_lower_node(_S_adapt(__nh._M_ptr));
2179 extract(const_iterator __pos)
2181 auto __ptr = _Node_traits::_S_rebalance_for_erase
2182 (__pos._M_node, _M_impl._M_header);
2183 --_M_impl._M_node_count;
2184 auto __node_ptr =
static_cast<_Node&
>(*__ptr)._M_node_ptr();
2185#if _GLIBCXX_USE_ALLOC_PTR_FOR_RB_TREE
2186 return { __node_ptr, _M_get_Node_allocator() };
2188#pragma GCC diagnostic push
2189#pragma GCC diagnostic ignored "-Wc++17-extensions"
2190 using __alloc_ptr =
typename _Node_alloc_traits::pointer;
2191 if constexpr (is_same<_Node_ptr, __alloc_ptr>::value)
2192 return { __node_ptr, _M_get_Node_allocator() };
2195 auto __ap = pointer_traits<__alloc_ptr>::pointer_to(*__node_ptr);
2196 return { __ap, _M_get_Node_allocator() };
2198#pragma GCC diagnostic pop
2204 extract(
const key_type& __k)
2207 auto __pos = find(__k);
2209 __nh = extract(const_iterator(__pos));
2213 template <
typename _Kt>
2215 _M_extract_tr(
const _Kt& __k)
2218 auto __pos = _M_find_tr(__k);
2220 __nh = extract(const_iterator(__pos));
2224 template<
typename _Compare2>
2225 using _Compatible_tree
2226 = _Rb_tree<_Key, _Val, _KeyOfValue, _Compare2, _Alloc>;
2228 template<
typename,
typename>
2229 friend struct _Rb_tree_merge_helper;
2232 template<
typename _Compare2>
2234 _M_merge_unique(_Compatible_tree<_Compare2>& __src)
noexcept
2236 using _Merge_helper = _Rb_tree_merge_helper<_Rb_tree, _Compare2>;
2237 for (
auto __i = __src.begin(), __end = __src.end(); __i != __end;)
2240 auto __res = _M_get_insert_unique_pos(_KeyOfValue()(*__pos));
2243 auto& __src_impl = _Merge_helper::_S_get_impl(__src);
2244 auto __ptr = _Node_traits::_S_rebalance_for_erase
2245 (__pos._M_node, __src_impl._M_header);
2246 --__src_impl._M_node_count;
2247 auto __node_ptr =
static_cast<_Node&
>(*__ptr)._M_node_ptr();
2248 _M_insert_node(__res.first, __res.second, __node_ptr);
2254 template<
typename _Compare2>
2256 _M_merge_equal(_Compatible_tree<_Compare2>& __src)
noexcept
2258 using _Merge_helper = _Rb_tree_merge_helper<_Rb_tree, _Compare2>;
2259 for (
auto __i = __src.begin(), __end = __src.end(); __i != __end;)
2262 auto __res = _M_get_insert_equal_pos(_KeyOfValue()(*__pos));
2265 auto& __src_impl = _Merge_helper::_S_get_impl(__src);
2266 auto __ptr = _Node_traits::_S_rebalance_for_erase
2267 (__pos._M_node, __src_impl._M_header);
2268 --__src_impl._M_node_count;
2269 auto __node_ptr =
static_cast<_Node&
>(*__ptr)._M_node_ptr();
2270 _M_insert_node(__res.first, __res.second, __node_ptr);
2277 operator==(
const _Rb_tree& __x,
const _Rb_tree& __y)
2279 return __x.size() == __y.size()
2280 && std::equal(__x.begin(), __x.end(), __y.begin());
2283#if __cpp_lib_three_way_comparison
2285 operator<=>(
const _Rb_tree& __x,
const _Rb_tree& __y)
2287 if constexpr (
requires {
typename __detail::__synth3way_t<_Val>; })
2289 __y.begin(), __y.end(),
2290 __detail::__synth3way);
2294 operator<(
const _Rb_tree& __x,
const _Rb_tree& __y)
2296 return std::lexicographical_compare(__x.begin(), __x.end(),
2297 __y.begin(), __y.end());
2302#if __cplusplus >= 201103L
2306 template<
typename... _Args>
2307 _Auto_node(_Rb_tree& __t, _Args&&... __args)
2309 _M_node(__t._M_create_node(std::
forward<_Args>(__args)...))
2315 _M_t._M_drop_node(_M_node);
2318 _Auto_node(_Auto_node&& __n)
2319 : _M_t(__n._M_t), _M_node(__n._M_node)
2320 { __n._M_node =
nullptr; }
2324 {
return _S_key(_M_node); }
2329 auto __it = _M_t._M_insert_node(__p.first, __p.second, _M_node);
2335 _M_insert_equal_lower()
2337 auto __it = _M_t._M_insert_equal_lower_node(_M_node);
2348 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2349 typename _Compare,
typename _Alloc>
2351 swap(_Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>& __x,
2352 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>& __y)
2355#if __cplusplus >= 201103L
2356 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2357 typename _Compare,
typename _Alloc>
2359 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2362 if (_M_get_Node_allocator() == __x._M_get_Node_allocator())
2366 constexpr bool __move = !__move_if_noexcept_cond<value_type>::value;
2367 _Alloc_node __an(*
this);
2368 _M_root() = _M_copy<__move>(__x, __an);
2369#pragma GCC diagnostic push
2370#pragma GCC diagnostic ignored "-Wc++17-extensions"
2371 if constexpr (__move)
2373#pragma GCC diagnostic pop
2377 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2378 typename _Compare,
typename _Alloc>
2380 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2381 _M_move_assign(_Rb_tree& __x,
true_type)
2386 std::__alloc_on_move(_M_get_Node_allocator(),
2387 __x._M_get_Node_allocator());
2390 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2391 typename _Compare,
typename _Alloc>
2393 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2396 if (_M_get_Node_allocator() == __x._M_get_Node_allocator())
2397 return _M_move_assign(__x,
true_type{});
2401 _Reuse_or_alloc_node __roan(*
this);
2405 _M_root() = _M_copy<__as_rvalue>(__x, __roan);
2410 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2411 typename _Compare,
typename _Alloc>
2412 inline _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>&
2413 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2414 operator=(_Rb_tree&& __x)
2415 noexcept(_Node_alloc_traits::_S_nothrow_move()
2418 _M_impl._M_key_compare =
std::move(__x._M_impl._M_key_compare);
2420 __bool_constant<_Node_alloc_traits::_S_nothrow_move()>());
2424 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2425 typename _Compare,
typename _Alloc>
2426 template<
typename _Iterator>
2428 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2429 _M_assign_unique(_Iterator __first, _Iterator __last)
2431 _Reuse_or_alloc_node __roan(*
this);
2433 for (; __first != __last; ++__first)
2434 _M_insert_unique_(
end(), *__first, __roan);
2437 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2438 typename _Compare,
typename _Alloc>
2439 template<
typename _Iterator>
2441 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2442 _M_assign_equal(_Iterator __first, _Iterator __last)
2444 _Reuse_or_alloc_node __roan(*
this);
2446 for (; __first != __last; ++__first)
2447 _M_insert_equal_(
end(), *__first, __roan);
2451 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2452 typename _Compare,
typename _Alloc>
2453 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>&
2454 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2455 operator=(
const _Rb_tree& __x)
2460#if __cplusplus >= 201103L
2461 if (_Node_alloc_traits::_S_propagate_on_copy_assign())
2463 auto& __this_alloc = this->_M_get_Node_allocator();
2464 auto& __that_alloc = __x._M_get_Node_allocator();
2465 if (!_Node_alloc_traits::_S_always_equal()
2466 && __this_alloc != __that_alloc)
2471 std::__alloc_on_copy(__this_alloc, __that_alloc);
2476 _Reuse_or_alloc_node __roan(*
this);
2478 _M_impl._M_key_compare = __x._M_impl._M_key_compare;
2480 _M_root() = _M_copy<__as_lvalue>(__x, __roan);
2486 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2487 typename _Compare,
typename _Alloc>
2488#if __cplusplus >= 201103L
2489 template<
typename _Arg,
typename _NodeGen>
2491 template<
typename _NodeGen>
2493 typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::iterator
2494 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2495 _M_insert_(_Base_ptr __x, _Base_ptr __p,
2496#
if __cplusplus >= 201103L
2501 _NodeGen& __node_gen)
2503 bool __insert_left = (__x || __p == _M_end()
2504 || _M_key_compare(_KeyOfValue()(__v),
2508 __node_gen(_GLIBCXX_FORWARD(_Arg, __v))->_M_base_ptr();
2510 _Node_traits::_S_insert_and_rebalance
2511 (__insert_left, __z, __p, this->_M_impl._M_header);
2512 ++_M_impl._M_node_count;
2516 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2517 typename _Compare,
typename _Alloc>
2518#if __cplusplus >= 201103L
2519 template<
typename _Arg>
2521 typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::iterator
2522 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2523#if __cplusplus >= 201103L
2524 _M_insert_lower(_Base_ptr __p, _Arg&& __v)
2526 _M_insert_lower(_Base_ptr __p,
const _Val& __v)
2529 bool __insert_left = (__p == _M_end()
2530 || !_M_key_compare(_S_key(__p),
2531 _KeyOfValue()(__v)));
2534 _M_create_node(_GLIBCXX_FORWARD(_Arg, __v))->_M_base_ptr();
2535 _Node_traits::_S_insert_and_rebalance
2536 (__insert_left, __z, __p, this->_M_impl._M_header);
2537 ++_M_impl._M_node_count;
2541 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2542 typename _Compare,
typename _Alloc>
2543#if __cplusplus >= 201103L
2544 template<
typename _Arg>
2546 typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::iterator
2547 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2548#if __cplusplus >= 201103L
2549 _M_insert_equal_lower(_Arg&& __v)
2551 _M_insert_equal_lower(
const _Val& __v)
2554 _Base_ptr __x = _M_begin();
2555 _Base_ptr __y = _M_end();
2559 __x = !_M_key_compare(_S_key(__x), _KeyOfValue()(__v)) ?
2560 _S_left(__x) : _S_right(__x);
2562 return _M_insert_lower(__y, _GLIBCXX_FORWARD(_Arg, __v));
2565 template<
typename _Key,
typename _Val,
typename _KoV,
2566 typename _Compare,
typename _Alloc>
2567 template<
bool _MoveValues,
typename _NodeGen>
2568 typename _Rb_tree<_Key, _Val, _KoV, _Compare, _Alloc>::_Base_ptr
2569 _Rb_tree<_Key, _Val, _KoV, _Compare, _Alloc>::
2570 _M_copy(_Node_ptr __x, _Base_ptr __p, _NodeGen& __node_gen)
2573 _Node_ptr __top = _M_clone_node<_MoveValues>(__x, __node_gen);
2574 _Base_ptr __top_base = __top->_M_base_ptr();
2575 __top->_M_parent = __p;
2581 _M_copy<_MoveValues>(_S_right(__x), __top_base, __node_gen);
2588 _M_clone_node<_MoveValues>(__x, __node_gen)->_M_base_ptr();
2590 __y->_M_parent = __p;
2592 __y->_M_right = _M_copy<_MoveValues>(_S_right(__x),
2601 __throw_exception_again;
2606 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2607 typename _Compare,
typename _Alloc>
2609 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2610 _M_erase(_Node_ptr __x)
2615 _M_erase(_S_right(__x));
2616 _Node_ptr __y = _S_left(__x);
2622 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2623 typename _Compare,
typename _Alloc>
2624 typename _Rb_tree<_Key, _Val, _KeyOfValue,
2625 _Compare, _Alloc>::_Base_ptr
2626 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2627 _M_lower_bound(_Base_ptr __x, _Base_ptr __y,
2628 const _Key& __k)
const
2631 if (!_M_key_compare(_S_key(__x), __k))
2632 __y = __x, __x = _S_left(__x);
2634 __x = _S_right(__x);
2638 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2639 typename _Compare,
typename _Alloc>
2640 template <
typename _Kt>
2641 typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::_Base_ptr
2642 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2643 _M_lower_bound_tr(_Base_ptr __x, _Base_ptr __y,
const _Kt& __k)
const
2646 if (!_M_key_compare(_S_key(__x), __k))
2647 __y = __x, __x = _S_left(__x);
2649 __x = _S_right(__x);
2653 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2654 typename _Compare,
typename _Alloc>
2655 typename _Rb_tree<_Key, _Val, _KeyOfValue,
2656 _Compare, _Alloc>::_Base_ptr
2657 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2658 _M_upper_bound(_Base_ptr __x, _Base_ptr __y,
2659 const _Key& __k)
const
2662 if (_M_key_compare(__k, _S_key(__x)))
2663 __y = __x, __x = _S_left(__x);
2665 __x = _S_right(__x);
2669 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2670 typename _Compare,
typename _Alloc>
2671 template <
typename _Kt>
2672 typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::_Base_ptr
2673 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2674 _M_upper_bound_tr(_Base_ptr __x, _Base_ptr __y,
const _Kt& __k)
const
2677 if (_M_key_compare(__k, _S_key(__x)))
2678 __y = __x, __x = _S_left(__x);
2680 __x = _S_right(__x);
2684 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2685 typename _Compare,
typename _Alloc>
2686 pair<
typename _Rb_tree<_Key, _Val, _KeyOfValue,
2687 _Compare, _Alloc>::iterator,
2688 typename _Rb_tree<_Key, _Val, _KeyOfValue,
2689 _Compare, _Alloc>::iterator>
2690 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2691 equal_range(
const _Key& __k)
2695 _Base_ptr __x = _M_begin();
2696 _Base_ptr __y = _M_end();
2699 if (_M_key_compare(_S_key(__x), __k))
2700 __x = _S_right(__x);
2701 else if (_M_key_compare(__k, _S_key(__x)))
2702 __y = __x, __x = _S_left(__x);
2705 _Base_ptr __xu(__x);
2706 _Base_ptr __yu(__y);
2707 __y = __x, __x = _S_left(__x);
2708 __xu = _S_right(__xu);
2709 return _Ret(
iterator(_M_lower_bound(__x, __y, __k)),
2710 iterator(_M_upper_bound(__xu, __yu, __k)));
2716 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2717 typename _Compare,
typename _Alloc>
2718 pair<
typename _Rb_tree<_Key, _Val, _KeyOfValue,
2719 _Compare, _Alloc>::const_iterator,
2720 typename _Rb_tree<_Key, _Val, _KeyOfValue,
2721 _Compare, _Alloc>::const_iterator>
2722 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2723 equal_range(
const _Key& __k)
const
2727 _Base_ptr __x = _M_begin();
2728 _Base_ptr __y = _M_end();
2731 if (_M_key_compare(_S_key(__x), __k))
2732 __x = _S_right(__x);
2733 else if (_M_key_compare(__k, _S_key(__x)))
2734 __y = __x, __x = _S_left(__x);
2737 _Base_ptr __xu(__x);
2738 _Base_ptr __yu(__y);
2739 __y = __x, __x = _S_left(__x);
2740 __xu = _S_right(__xu);
2741 return _Ret(const_iterator(_M_lower_bound(__x, __y, __k)),
2742 const_iterator(_M_upper_bound(__xu, __yu, __k)));
2745 return _Ret(const_iterator(__y), const_iterator(__y));
2748 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2749 typename _Compare,
typename _Alloc>
2751 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2753 _GLIBCXX_NOEXCEPT_IF(__is_nothrow_swappable<_Compare>::value)
2758 _M_impl._M_move_data(__t._M_impl);
2760 else if (!__t._M_root())
2761 __t._M_impl._M_move_data(_M_impl);
2764 std::swap(_M_root(),__t._M_root());
2765 std::swap(_M_leftmost(),__t._M_leftmost());
2766 std::swap(_M_rightmost(),__t._M_rightmost());
2768 _M_root()->_M_parent = _M_end();
2769 __t._M_root()->_M_parent = __t._M_end();
2770 std::swap(this->_M_impl._M_node_count, __t._M_impl._M_node_count);
2775 swap(this->_M_impl._M_key_compare, __t._M_impl._M_key_compare);
2777 _Node_alloc_traits::_S_on_swap(_M_get_Node_allocator(),
2778 __t._M_get_Node_allocator());
2781 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2782 typename _Compare,
typename _Alloc>
2783 pair<
typename _Rb_tree<_Key, _Val, _KeyOfValue,
2784 _Compare, _Alloc>::_Base_ptr,
2785 typename _Rb_tree<_Key, _Val, _KeyOfValue,
2786 _Compare, _Alloc>::_Base_ptr>
2787 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2788 _M_get_insert_unique_pos(
const key_type& __k)
2791 _Base_ptr __x = _M_begin();
2792 _Base_ptr __y = _M_end();
2797 __comp = _M_key_compare(__k, _S_key(__x));
2798 __x = __comp ? _S_left(__x) : _S_right(__x);
2804 return _Res(__x, __y);
2808 if (_M_key_compare(_S_key(__j._M_node), __k))
2809 return _Res(__x, __y);
2810 return _Res(__j._M_node, _Base_ptr());
2813 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2814 typename _Compare,
typename _Alloc>
2815 pair<
typename _Rb_tree<_Key, _Val, _KeyOfValue,
2816 _Compare, _Alloc>::_Base_ptr,
2817 typename _Rb_tree<_Key, _Val, _KeyOfValue,
2818 _Compare, _Alloc>::_Base_ptr>
2819 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2820 _M_get_insert_equal_pos(
const key_type& __k)
2823 _Base_ptr __x = _M_begin();
2824 _Base_ptr __y = _M_end();
2828 __x = _M_key_compare(__k, _S_key(__x)) ? _S_left(__x) : _S_right(__x);
2830 return _Res(__x, __y);
2833 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2834 typename _Compare,
typename _Alloc>
2835#if __cplusplus >= 201103L
2836 template<
typename _Arg>
2838 pair<
typename _Rb_tree<_Key, _Val, _KeyOfValue,
2839 _Compare, _Alloc>::iterator,
bool>
2840 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2841#if __cplusplus >= 201103L
2842 _M_insert_unique(_Arg&& __v)
2844 _M_insert_unique(
const _Val& __v)
2849 = _M_get_insert_unique_pos(_KeyOfValue()(__v));
2853 _Alloc_node __an(*
this);
2854 return _Res(_M_insert_(__res.first, __res.second,
2855 _GLIBCXX_FORWARD(_Arg, __v), __an),
2859 return _Res(
iterator(__res.first),
false);
2862 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2863 typename _Compare,
typename _Alloc>
2864#if __cplusplus >= 201103L
2865 template<
typename _Arg>
2867 typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::iterator
2868 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2869#if __cplusplus >= 201103L
2870 _M_insert_equal(_Arg&& __v)
2872 _M_insert_equal(
const _Val& __v)
2876 = _M_get_insert_equal_pos(_KeyOfValue()(__v));
2877 _Alloc_node __an(*
this);
2878 return _M_insert_(__res.first, __res.second,
2879 _GLIBCXX_FORWARD(_Arg, __v), __an);
2882 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2883 typename _Compare,
typename _Alloc>
2884 pair<
typename _Rb_tree<_Key, _Val, _KeyOfValue,
2885 _Compare, _Alloc>::_Base_ptr,
2886 typename _Rb_tree<_Key, _Val, _KeyOfValue,
2887 _Compare, _Alloc>::_Base_ptr>
2888 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2889 _M_get_insert_hint_unique_pos(const_iterator __position,
2890 const key_type& __k)
2895 if (__position._M_node == _M_end())
2897 if (
size() > 0 && _M_key_compare(_S_key(_M_rightmost()), __k))
2898 return _Res(_Base_ptr(), _M_rightmost());
2900 return _M_get_insert_unique_pos(__k);
2902 else if (_M_key_compare(__k, _S_key(__position._M_node)))
2905 iterator __before(__position._M_node);
2906 if (__position._M_node == _M_leftmost())
2907 return _Res(_M_leftmost(), _M_leftmost());
2908 else if (_M_key_compare(_S_key((--__before)._M_node), __k))
2910 if (!_S_right(__before._M_node))
2911 return _Res(_Base_ptr(), __before._M_node);
2913 return _Res(__position._M_node, __position._M_node);
2916 return _M_get_insert_unique_pos(__k);
2918 else if (_M_key_compare(_S_key(__position._M_node), __k))
2921 iterator __after(__position._M_node);
2922 if (__position._M_node == _M_rightmost())
2923 return _Res(_Base_ptr(), _M_rightmost());
2924 else if (_M_key_compare(__k, _S_key((++__after)._M_node)))
2926 if (!_S_right(__position._M_node))
2927 return _Res(_Base_ptr(), __position._M_node);
2929 return _Res(__after._M_node, __after._M_node);
2932 return _M_get_insert_unique_pos(__k);
2936 return _Res(__position._M_node, _Base_ptr());
2939 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2940 typename _Compare,
typename _Alloc>
2941#if __cplusplus >= 201103L
2942 template<
typename _Arg,
typename _NodeGen>
2944 template<
typename _NodeGen>
2946 typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::iterator
2947 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2948 _M_insert_unique_(const_iterator __position,
2949#
if __cplusplus >= 201103L
2954 _NodeGen& __node_gen)
2957 = _M_get_insert_hint_unique_pos(__position, _KeyOfValue()(__v));
2960 return _M_insert_(__res.first, __res.second,
2961 _GLIBCXX_FORWARD(_Arg, __v),
2966 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
2967 typename _Compare,
typename _Alloc>
2968 pair<
typename _Rb_tree<_Key, _Val, _KeyOfValue,
2969 _Compare, _Alloc>::_Base_ptr,
2970 typename _Rb_tree<_Key, _Val, _KeyOfValue,
2971 _Compare, _Alloc>::_Base_ptr>
2972 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
2973 _M_get_insert_hint_equal_pos(const_iterator __position,
const key_type& __k)
2978 if (__position._M_node == _M_end())
2981 && !_M_key_compare(__k, _S_key(_M_rightmost())))
2982 return _Res(_Base_ptr(), _M_rightmost());
2984 return _M_get_insert_equal_pos(__k);
2986 else if (!_M_key_compare(_S_key(__position._M_node), __k))
2989 iterator __before(__position._M_node);
2990 if (__position._M_node == _M_leftmost())
2991 return _Res(_M_leftmost(), _M_leftmost());
2992 else if (!_M_key_compare(__k, _S_key((--__before)._M_node)))
2994 if (!_S_right(__before._M_node))
2995 return _Res(_Base_ptr(), __before._M_node);
2997 return _Res(__position._M_node, __position._M_node);
3000 return _M_get_insert_equal_pos(__k);
3005 iterator __after(__position._M_node);
3006 if (__position._M_node == _M_rightmost())
3007 return _Res(_Base_ptr(), _M_rightmost());
3008 else if (!_M_key_compare(_S_key((++__after)._M_node), __k))
3010 if (!_S_right(__position._M_node))
3011 return _Res(_Base_ptr(), __position._M_node);
3013 return _Res(__after._M_node, __after._M_node);
3016 return _Res(_Base_ptr(), _Base_ptr());
3020 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3021 typename _Compare,
typename _Alloc>
3022#if __cplusplus >= 201103L
3023 template<
typename _Arg,
typename _NodeGen>
3025 template<
typename _NodeGen>
3027 typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::iterator
3028 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3029 _M_insert_equal_(const_iterator __position,
3030#
if __cplusplus >= 201103L
3035 _NodeGen& __node_gen)
3038 = _M_get_insert_hint_equal_pos(__position, _KeyOfValue()(__v));
3041 return _M_insert_(__res.first, __res.second,
3042 _GLIBCXX_FORWARD(_Arg, __v),
3045 return _M_insert_equal_lower(_GLIBCXX_FORWARD(_Arg, __v));
3048#if __cplusplus >= 201103L
3049 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3050 typename _Compare,
typename _Alloc>
3052 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3053 _M_insert_node(_Base_ptr __x, _Base_ptr __p, _Node_ptr __z)
3056 bool __insert_left = (__x || __p == _M_end()
3057 || _M_key_compare(_S_key(__z), _S_key(__p)));
3059 _Base_ptr __base_z = __z->_M_base_ptr();
3060 _Node_traits::_S_insert_and_rebalance
3061 (__insert_left, __base_z, __p, this->_M_impl._M_header);
3062 ++_M_impl._M_node_count;
3066 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3067 typename _Compare,
typename _Alloc>
3069 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3070 _M_insert_lower_node(_Base_ptr __p, _Node_ptr __z)
3073 bool __insert_left = (__p == _M_end()
3074 || !_M_key_compare(_S_key(__p), _S_key(__z)));
3076 _Base_ptr __base_z = __z->_M_base_ptr();
3077 _Node_traits::_S_insert_and_rebalance
3078 (__insert_left, __base_z, __p, this->_M_impl._M_header);
3079 ++_M_impl._M_node_count;
3083 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3084 typename _Compare,
typename _Alloc>
3086 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3087 _M_insert_equal_lower_node(_Node_ptr __z)
3090 _Base_ptr __x = _M_begin();
3091 _Base_ptr __y = _M_end();
3095 __x = !_M_key_compare(_S_key(__x), _S_key(__z)) ?
3096 _S_left(__x) : _S_right(__x);
3098 return _M_insert_lower_node(__y, __z);
3101 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3102 typename _Compare,
typename _Alloc>
3103 template<
typename... _Args>
3105 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3106 _M_emplace_unique(_Args&&... __args)
3110 auto __res = _M_get_insert_unique_pos(__z._M_key());
3112 return {__z._M_insert(__res),
true};
3113 return {
iterator(__res.first),
false};
3116 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3117 typename _Compare,
typename _Alloc>
3118 template<
typename... _Args>
3120 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3121 _M_emplace_equal(_Args&&... __args)
3125 auto __res = _M_get_insert_equal_pos(__z._M_key());
3126 return __z._M_insert(__res);
3129 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3130 typename _Compare,
typename _Alloc>
3131 template<
typename... _Args>
3133 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3134 _M_emplace_hint_unique(const_iterator __pos, _Args&&... __args)
3138 auto __res = _M_get_insert_hint_unique_pos(__pos, __z._M_key());
3140 return __z._M_insert(__res);
3144 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3145 typename _Compare,
typename _Alloc>
3146 template<
typename... _Args>
3148 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3149 _M_emplace_hint_equal(const_iterator __pos, _Args&&... __args)
3153 auto __res = _M_get_insert_hint_equal_pos(__pos, __z._M_key());
3155 return __z._M_insert(__res);
3156 return __z._M_insert_equal_lower();
3161 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3162 typename _Compare,
typename _Alloc>
3164 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3165 _M_erase_aux(const_iterator __position)
3167 _Base_ptr __y = _Node_traits::_S_rebalance_for_erase
3168 (__position._M_node, this->_M_impl._M_header);
3169 _M_drop_node(
static_cast<_Node&
>(*__y)._M_node_ptr());
3170 --_M_impl._M_node_count;
3173 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3174 typename _Compare,
typename _Alloc>
3176 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3177 _M_erase_aux(const_iterator __first, const_iterator __last)
3179 if (__first ==
begin() && __last ==
end())
3182 while (__first != __last)
3183 _M_erase_aux(__first++);
3186 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3187 typename _Compare,
typename _Alloc>
3188 typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::size_type
3189 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3190 erase(
const _Key& __x)
3194 _M_erase_aux(__p.first, __p.second);
3195 return __old_size -
size();
3198 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3199 typename _Compare,
typename _Alloc>
3200 template <
typename _Kt>
3201 typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::size_type
3202 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3203 _M_erase_tr(
const _Kt& __x)
3207 _M_erase_aux(__p.first, __p.second);
3208 return __old_size -
size();
3211 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3212 typename _Compare,
typename _Alloc>
3213 typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::size_type
3214 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3215 _M_erase_unique(
const _Key& __x)
3225 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3226 typename _Compare,
typename _Alloc>
3227 typename _Rb_tree<_Key, _Val, _KeyOfValue,
3228 _Compare, _Alloc>::iterator
3229 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3230 find(
const _Key& __k)
3232 iterator __j(_M_lower_bound(_M_begin(), _M_end(), __k));
3233 return (__j ==
end()
3234 || _M_key_compare(__k, _S_key(__j._M_node))) ?
end() : __j;
3237 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3238 typename _Compare,
typename _Alloc>
3239 typename _Rb_tree<_Key, _Val, _KeyOfValue,
3240 _Compare, _Alloc>::const_iterator
3241 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3242 find(
const _Key& __k)
const
3244 const_iterator __j(_M_lower_bound(_M_begin(), _M_end(), __k));
3245 return (__j ==
end()
3246 || _M_key_compare(__k, _S_key(__j._M_node))) ?
end() : __j;
3249 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3250 typename _Compare,
typename _Alloc>
3251 typename _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::size_type
3252 _Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::
3253 count(
const _Key& __k)
const
3260 _GLIBCXX_PURE
unsigned int
3261 _Rb_tree_black_count(
const _Rb_tree_node_base* __node,
3262 const _Rb_tree_node_base* __root)
throw ();
3264 template<
typename _Key,
typename _Val,
typename _KeyOfValue,
3265 typename _Compare,
typename _Alloc>
3267 _Rb_tree<_Key,_Val,_KeyOfValue,_Compare,_Alloc>::__rb_verify()
const
3269 if (_M_impl._M_node_count == 0 ||
begin() ==
end())
3270 return _M_impl._M_node_count == 0 &&
begin() ==
end()
3271 && this->_M_impl._M_header._M_left == _M_end()
3272 && this->_M_impl._M_header._M_right == _M_end();
3274 unsigned int __len = _Rb_tree_black_count(_M_leftmost(), _M_root());
3275 for (const_iterator __it =
begin(); __it !=
end(); ++__it)
3277 _Base_ptr __x = __it._M_node;
3278 _Base_ptr __L = _S_left(__x);
3279 _Base_ptr __R = _S_right(__x);
3281 if (__x->_M_color == _S_red)
3282 if ((__L && __L->_M_color == _S_red)
3283 || (__R && __R->_M_color == _S_red))
3286 if (__L && _M_key_compare(_S_key(__x), _S_key(__L)))
3288 if (__R && _M_key_compare(_S_key(__R), _S_key(__x)))
3291 if (!__L && !__R && _Rb_tree_black_count(__x, _M_root()) != __len)
3295 if (_M_leftmost() != _Node_base::_S_minimum(_M_root()))
3297 if (_M_rightmost() != _Node_base::_S_maximum(_M_root()))
3302#ifdef __glibcxx_node_extract
3304 template<
typename _Key,
typename _Val,
typename _Sel,
typename _Cmp1,
3305 typename _Alloc,
typename _Cmp2>
3306 struct _Rb_tree_merge_helper<_Rb_tree<_Key, _Val, _Sel, _Cmp1, _Alloc>,
3310 friend class _Rb_tree<_Key, _Val, _Sel, _Cmp1, _Alloc>;
3313 _S_get_impl(_Rb_tree<_Key, _Val, _Sel, _Cmp2, _Alloc>& __tree)
3314 {
return __tree._M_impl; }
3318#ifdef __glibcxx_associative_heterogeneous_erasure
3319template <
typename _Kt,
typename _Container>
3320 concept __heterogeneous_tree_key =
3321 __transparent_comparator<typename _Container::key_compare> &&
3322 __heterogeneous_key<_Kt, _Container>;
3325_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