#pragma GCC system_header
#endif
+#define __glibcxx_want_constexpr_flat_set
#define __glibcxx_want_flat_set
#include <bits/version.h>
{
container_type* _M_cont;
+ _GLIBCXX26_CONSTEXPR
_ClearGuard(container_type& __cont)
: _M_cont(std::__addressof(__cont))
{ }
+ _GLIBCXX26_CONSTEXPR
~_ClearGuard()
{
if (_M_cont)
_M_cont->clear();
}
+ _GLIBCXX26_CONSTEXPR
void
_M_disable()
{ _M_cont = nullptr; }
};
+ _GLIBCXX26_CONSTEXPR
_ClearGuard
_M_make_clear_guard()
{ return _ClearGuard{this->_M_cont}; }
public:
// constructors
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl() : _Flat_set_impl(key_compare()) { }
+ _GLIBCXX26_CONSTEXPR
explicit
_Flat_set_impl(const key_compare& __comp)
: _M_cont(), _M_comp(__comp)
{ }
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(container_type __cont, const key_compare& __comp = key_compare())
: _M_cont(std::move(__cont)), _M_comp(__comp)
{ _M_sort_uniq(); }
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(__sorted_t,
container_type __cont, const key_compare& __comp = key_compare())
: _M_cont(std::move(__cont)), _M_comp(__comp)
{ _GLIBCXX_DEBUG_ASSERT(ranges::is_sorted(_M_cont, _M_comp)); }
template<__has_input_iter_cat _InputIterator>
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(_InputIterator __first, _InputIterator __last,
const key_compare& __comp = key_compare())
: _M_cont(), _M_comp(__comp)
{ insert(__first, __last); }
template<__has_input_iter_cat _InputIterator>
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(__sorted_t __s,
_InputIterator __first, _InputIterator __last,
const key_compare& __comp = key_compare())
{ insert(__s, __first, __last); }
template<__detail::__container_compatible_range<value_type> _Rg>
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(from_range_t, _Rg&& __rg)
: _Flat_set_impl(from_range, std::forward<_Rg>(__rg), key_compare())
{ }
template<__detail::__container_compatible_range<value_type> _Rg>
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(from_range_t, _Rg&& __rg, const key_compare& __comp)
: _Flat_set_impl(__comp)
{ insert_range(std::forward<_Rg>(__rg)); }
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(initializer_list<value_type> __il,
const key_compare& __comp = key_compare())
: _Flat_set_impl(__il.begin(), __il.end(), __comp)
{ }
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(__sorted_t __s,
initializer_list<value_type> __il,
const key_compare& __comp = key_compare())
// constructors with allocators
template<__allocator_for<container_type> _Alloc>
+ _GLIBCXX26_CONSTEXPR
explicit
_Flat_set_impl(const _Alloc& __a)
: _Flat_set_impl(key_compare(), __a)
{ }
template<__allocator_for<container_type> _Alloc>
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(const key_compare& __comp, const _Alloc& __a)
: _M_cont(std::make_obj_using_allocator<container_type>(__a)),
_M_comp(__comp)
{ }
template<__allocator_for<container_type> _Alloc>
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(const container_type& __cont, const _Alloc& __a)
: _Flat_set_impl(__cont, key_compare(), __a)
{ }
template<__allocator_for<container_type> _Alloc>
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(const container_type& __cont, const key_compare& __comp,
const _Alloc& __a)
: _M_cont(std::make_obj_using_allocator<container_type>(__a, __cont)),
{ _M_sort_uniq(); }
template<__allocator_for<container_type> _Alloc>
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(__sorted_t __s, const container_type& __cont, const _Alloc& __a)
: _Flat_set_impl(__s, __cont, key_compare(), __a)
{ }
template<__allocator_for<container_type> _Alloc>
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(__sorted_t, const container_type& __cont, const key_compare& __comp,
const _Alloc& __a)
: _M_cont(std::make_obj_using_allocator<container_type>(__a, __cont)),
{ _GLIBCXX_DEBUG_ASSERT(ranges::is_sorted(_M_cont, _M_comp)); }
template<__allocator_for<container_type> _Alloc>
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(const _Derived& __x, const _Alloc& __a)
: _M_cont(std::make_obj_using_allocator<container_type>(__a, __x._M_cont)),
_M_comp(__x._M_comp)
{ }
template<__allocator_for<container_type> _Alloc>
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(_Derived&& __x, const _Alloc& __a)
: _M_cont(std::make_obj_using_allocator<container_type>(__a, std::move(__x._M_cont))),
_M_comp(__x._M_comp)
{ }
template<__has_input_iter_cat _InputIterator, __allocator_for<container_type> _Alloc>
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(_InputIterator __first, _InputIterator __last,
const _Alloc& __a)
: _Flat_set_impl(std::move(__first), std::move(__last), key_compare(), __a)
{ }
template<__has_input_iter_cat _InputIterator, __allocator_for<container_type> _Alloc>
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(_InputIterator __first, _InputIterator __last,
const key_compare& __comp,
const _Alloc& __a)
{ insert(__first, __last); }
template<__has_input_iter_cat _InputIterator, __allocator_for<container_type> _Alloc>
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(__sorted_t __s,
_InputIterator __first, _InputIterator __last,
const _Alloc& __a)
{ }
template<__has_input_iter_cat _InputIterator, __allocator_for<container_type> _Alloc>
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(__sorted_t __s,
_InputIterator __first, _InputIterator __last,
const key_compare& __comp,
template<__detail::__container_compatible_range<value_type> _Rg,
__allocator_for<container_type> _Alloc>
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(from_range_t, _Rg&& __rg,
const _Alloc& __a)
: _Flat_set_impl(from_range, std::forward<_Rg>(__rg), key_compare(), __a)
template<__detail::__container_compatible_range<value_type> _Rg,
__allocator_for<container_type> _Alloc>
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(from_range_t, _Rg&& __rg,
const key_compare& __comp,
const _Alloc& __a)
{ insert_range(std::forward<_Rg>(__rg)); }
template<__allocator_for<container_type> _Alloc>
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(initializer_list<value_type> __il,
const _Alloc& __a)
: _Flat_set_impl(__il, key_compare(), __a)
{ }
template<__allocator_for<container_type> _Alloc>
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(initializer_list<value_type> __il,
const key_compare& __comp,
const _Alloc& __a)
{ }
template<__allocator_for<container_type> _Alloc>
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(__sorted_t __s,
initializer_list<value_type> __il,
const _Alloc& __a)
{ }
template<__allocator_for<container_type> _Alloc>
+ _GLIBCXX26_CONSTEXPR
_Flat_set_impl(__sorted_t __s,
initializer_list<value_type> __il,
const key_compare& __comp,
: _Flat_set_impl(__s, __il.begin(), __il.end(), __comp, __a)
{ }
+ _GLIBCXX26_CONSTEXPR
_Derived&
operator=(initializer_list<value_type> __il)
{
}
// iterators
+ _GLIBCXX26_CONSTEXPR
const_iterator
begin() const noexcept
{ return _M_cont.begin(); }
+ _GLIBCXX26_CONSTEXPR
const_iterator
end() const noexcept
{ return _M_cont.end(); }
+ _GLIBCXX26_CONSTEXPR
const_reverse_iterator
rbegin() const noexcept
{ return const_reverse_iterator(end()); }
+ _GLIBCXX26_CONSTEXPR
const_reverse_iterator
rend() const noexcept
{ return const_reverse_iterator(begin()); }
+ _GLIBCXX26_CONSTEXPR
const_iterator
cbegin() const noexcept
{ return begin(); }
+ _GLIBCXX26_CONSTEXPR
const_iterator
cend() const noexcept
{ return end(); }
+ _GLIBCXX26_CONSTEXPR
const_reverse_iterator
crbegin() const noexcept
{ return rbegin(); }
+ _GLIBCXX26_CONSTEXPR
const_reverse_iterator
crend() const noexcept
{ return rend(); }
// capacity
[[nodiscard]]
+ _GLIBCXX26_CONSTEXPR
bool
empty() const noexcept
{ return _M_cont.empty(); }
+ _GLIBCXX26_CONSTEXPR
size_type
size() const noexcept
{ return _M_cont.size(); }
+ _GLIBCXX26_CONSTEXPR
size_type
max_size() const noexcept
{ return _M_cont.max_size(); }
// modifiers
template<typename _Arg, typename... _Args>
+ _GLIBCXX26_CONSTEXPR
pair<iterator, bool>
_M_try_emplace(optional<const_iterator> __hint, _Arg&& __arg, _Args&&... __args)
{
}
template<typename... _Args>
+ _GLIBCXX26_CONSTEXPR
pair<iterator, bool>
_M_try_emplace(optional<const_iterator> __hint)
{ return _M_try_emplace(__hint, value_type()); }
template<typename... _Args>
requires is_constructible_v<value_type, _Args...>
+ _GLIBCXX26_CONSTEXPR
__emplace_result_t
emplace(_Args&&... __args)
{
}
template<typename... _Args>
+ _GLIBCXX26_CONSTEXPR
iterator
emplace_hint(const_iterator __position, _Args&&... __args)
{ return _M_try_emplace(__position, std::forward<_Args>(__args)...).first; }
+ _GLIBCXX26_CONSTEXPR
__emplace_result_t
insert(const value_type& __x)
{ return emplace(__x); }
+ _GLIBCXX26_CONSTEXPR
__emplace_result_t
insert(value_type&& __x)
{ return emplace(std::move(__x)); }
+ _GLIBCXX26_CONSTEXPR
iterator
insert(const_iterator __position, const value_type& __x)
{ return emplace_hint(__position, __x); }
+ _GLIBCXX26_CONSTEXPR
iterator
insert(const_iterator __position, value_type&& __x)
{ return emplace_hint(__position, std::move(__x)); }
template<typename _Arg>
requires is_constructible_v<value_type, _Arg>
+ _GLIBCXX26_CONSTEXPR
__emplace_result_t
insert(_Arg&& __x)
{ return emplace(std::forward<_Arg>(__x)); }
template<typename _Arg>
requires is_constructible_v<value_type, _Arg>
+ _GLIBCXX26_CONSTEXPR
iterator
insert(const_iterator __position, _Arg&& __x)
{ return emplace_hint(__position, std::forward<_Arg>(__x)); }
template<__has_input_iter_cat _InputIterator>
+ _GLIBCXX26_CONSTEXPR
void
insert(_InputIterator __first, _InputIterator __last)
{
}
template<__has_input_iter_cat _InputIterator>
+ _GLIBCXX26_CONSTEXPR
void
insert(__sorted_t, _InputIterator __first, _InputIterator __last)
{
}
template<__detail::__container_compatible_range<value_type> _Rg>
+ _GLIBCXX26_CONSTEXPR
void
insert_range(_Rg&& __rg)
{
__guard._M_disable();
}
+ _GLIBCXX26_CONSTEXPR
void
insert(initializer_list<value_type> __il)
{ insert(__il.begin(), __il.end()); }
+ _GLIBCXX26_CONSTEXPR
void
insert(__sorted_t __s, initializer_list<value_type> __il)
{ insert(__s, __il.begin(), __il.end()); }
+ _GLIBCXX26_CONSTEXPR
container_type
extract() &&
{
return std::move(_M_cont);
}
+ _GLIBCXX26_CONSTEXPR
void
replace(container_type&& __cont)
{
__guard._M_disable();
}
+ _GLIBCXX26_CONSTEXPR
iterator
erase(const_iterator __position)
{ return _M_cont.erase(__position); }
+ _GLIBCXX26_CONSTEXPR
size_type
erase(const key_type& __x)
{ return erase<const key_type&>(__x); }
|| (__transparent_comparator<_Compare>
&& !is_convertible_v<_Key2, iterator>
&& !is_convertible_v<_Key2, const_iterator>)
+ _GLIBCXX26_CONSTEXPR
size_type
erase(_Key2&& __x)
{
return __n;
}
+ _GLIBCXX26_CONSTEXPR
iterator
erase(const_iterator __first, const_iterator __last)
{ return _M_cont.erase(__first, __last); }
+ _GLIBCXX26_CONSTEXPR
void
swap(_Derived& __x) noexcept
{
swap(_M_comp, __x._M_comp);
}
+ _GLIBCXX26_CONSTEXPR
void
clear() noexcept
{ _M_cont.clear(); }
// observers
[[nodiscard]]
+ _GLIBCXX26_CONSTEXPR
key_compare
key_comp() const
{ return _M_comp; }
[[nodiscard]]
+ _GLIBCXX26_CONSTEXPR
value_compare
value_comp() const
{ return _M_comp; }
// set operations
[[nodiscard]]
+ _GLIBCXX26_CONSTEXPR
iterator
find(const key_type& __x)
{ return find<key_type>(__x); }
[[nodiscard]]
+ _GLIBCXX26_CONSTEXPR
const_iterator
find(const key_type& __x) const
{ return find<key_type>(__x); }
template<typename _Key2>
requires same_as<_Key2, _Key> || __transparent_comparator<_Compare>
[[nodiscard]]
+ _GLIBCXX26_CONSTEXPR
iterator
find(const _Key2& __x)
{
template<typename _Key2>
requires same_as<_Key2, _Key> || __transparent_comparator<_Compare>
[[nodiscard]]
+ _GLIBCXX26_CONSTEXPR
const_iterator
find(const _Key2& __x) const
{
}
[[nodiscard]]
+ _GLIBCXX26_CONSTEXPR
size_type
count(const key_type& __x) const
{ return count<key_type>(__x); }
template<typename _Key2>
requires same_as<_Key2, _Key> || __transparent_comparator<_Compare>
[[nodiscard]]
+ _GLIBCXX26_CONSTEXPR
size_type
count(const _Key2& __x) const
{
}
[[nodiscard]]
+ _GLIBCXX26_CONSTEXPR
bool
contains(const key_type& __x) const
{ return contains<key_type>(__x); }
template<typename _Key2>
requires same_as<_Key2, _Key> || __transparent_comparator<_Compare>
[[nodiscard]]
+ _GLIBCXX26_CONSTEXPR
bool
contains(const _Key2& __x) const
{ return find(__x) != cend(); }
[[nodiscard]]
+ _GLIBCXX26_CONSTEXPR
iterator
lower_bound(const key_type& __x)
{ return lower_bound<key_type>(__x); }
[[nodiscard]]
+ _GLIBCXX26_CONSTEXPR
const_iterator
lower_bound(const key_type& __x) const
{ return lower_bound<key_type>(__x); }
template<typename _Key2>
requires same_as<_Key2, _Key> || __transparent_comparator<_Compare>
[[nodiscard]]
+ _GLIBCXX26_CONSTEXPR
iterator
lower_bound(const _Key2& __x)
{ return std::lower_bound(begin(), end(), __x, _M_comp); }
template<typename _Key2>
requires same_as<_Key2, _Key> || __transparent_comparator<_Compare>
[[nodiscard]]
+ _GLIBCXX26_CONSTEXPR
const_iterator
lower_bound(const _Key2& __x) const
{ return std::lower_bound(begin(), end(), __x, _M_comp); }
[[nodiscard]]
+ _GLIBCXX26_CONSTEXPR
iterator
upper_bound(const key_type& __x)
{ return upper_bound<key_type>(__x); }
[[nodiscard]]
+ _GLIBCXX26_CONSTEXPR
const_iterator
upper_bound(const key_type& __x) const
{ return upper_bound<key_type>(__x); }
template<typename _Key2>
requires same_as<_Key2, _Key> || __transparent_comparator<_Compare>
[[nodiscard]]
+ _GLIBCXX26_CONSTEXPR
iterator
upper_bound(const _Key2& __x)
{ return std::upper_bound(begin(), end(), __x, _M_comp); }
template<typename _Key2>
requires same_as<_Key2, _Key> || __transparent_comparator<_Compare>
[[nodiscard]]
+ _GLIBCXX26_CONSTEXPR
const_iterator
upper_bound(const _Key2& __x) const
{ return std::upper_bound(begin(), end(), __x, _M_comp); }
[[nodiscard]]
+ _GLIBCXX26_CONSTEXPR
pair<iterator, iterator>
equal_range(const key_type& __x)
{ return equal_range<key_type>(__x); }
[[nodiscard]]
+ _GLIBCXX26_CONSTEXPR
pair<const_iterator, const_iterator>
equal_range(const key_type& __x) const
{ return equal_range<key_type>(__x); }
template<typename _Key2>
requires same_as<_Key2, _Key> || __transparent_comparator<_Compare>
[[nodiscard]]
+ _GLIBCXX26_CONSTEXPR
pair<iterator, iterator>
equal_range(const _Key2& __x)
{ return std::equal_range(begin(), end(), __x, _M_comp); }
template<typename _Key2>
requires same_as<_Key2, _Key> || __transparent_comparator<_Compare>
[[nodiscard]]
+ _GLIBCXX26_CONSTEXPR
pair<const_iterator, const_iterator>
equal_range(const _Key2& __x) const
{ return std::equal_range(begin(), end(), __x, _M_comp); }
[[nodiscard]]
- friend bool
+ friend _GLIBCXX26_CONSTEXPR bool
operator==(const _Derived& __x, const _Derived& __y)
{ return std::equal(__x.begin(), __x.end(), __y.begin(), __y.end()); }
template<typename _Up = value_type>
[[nodiscard]]
- friend __detail::__synth3way_t<_Up>
+ friend _GLIBCXX26_CONSTEXPR __detail::__synth3way_t<_Up>
operator<=>(const _Derived& __x, const _Derived& __y)
{
return std::lexicographical_compare_three_way(__x.begin(), __x.end(),
__detail::__synth3way);
}
- friend void
+ friend _GLIBCXX26_CONSTEXPR void
swap(_Derived& __x, _Derived& __y) noexcept
{ return __x.swap(__y); }
template<typename _Predicate>
+ _GLIBCXX26_CONSTEXPR
size_type
_M_erase_if(_Predicate __pred)
{
container_type _M_cont;
[[no_unique_address]] _Compare _M_comp;
+ _GLIBCXX26_CONSTEXPR
void
_M_sort_uniq()
{
_M_unique();
}
+ _GLIBCXX26_CONSTEXPR
void
_M_unique() requires (!_Multi)
{
struct __key_equiv
{
+ _GLIBCXX26_CONSTEXPR
__key_equiv(key_compare __c) : _M_comp(__c) { }
+ _GLIBCXX26_CONSTEXPR
bool
operator()(const_reference __x, const_reference __y) const
{ return !_M_comp(__x, __y) && !_M_comp(__y, __x); }
template<typename _Key, typename _Compare, typename _KeyContainer,
typename _Predicate>
+ _GLIBCXX26_CONSTEXPR
typename flat_set<_Key, _Compare, _KeyContainer>::size_type
erase_if(flat_set<_Key, _Compare, _KeyContainer>& __c, _Predicate __pred)
{ return __c._M_erase_if(std::move(__pred)); }
template<typename _Key, typename _Compare, typename _KeyContainer,
typename _Predicate>
+ _GLIBCXX26_CONSTEXPR
typename flat_multiset<_Key, _Compare, _KeyContainer>::size_type
erase_if(flat_multiset<_Key, _Compare, _KeyContainer>& __c, _Predicate __pred)
{ return __c._M_erase_if(std::move(__pred)); }