30#ifndef _GLIBCXX_OPTIONAL
31#define _GLIBCXX_OPTIONAL 1
34#pragma GCC system_header
37#define __glibcxx_want_freestanding_optional
38#define __glibcxx_want_optional
39#define __glibcxx_want_optional_range_support
40#define __glibcxx_want_constrained_equality
41#define __glibcxx_want_constexpr_exceptions
42#define __glibcxx_want_hardened_optional
45#ifdef __cpp_lib_optional
56#if __cplusplus > 201703L
60#if __cplusplus > 202002L
63#ifdef __cpp_lib_optional_range_support
71namespace std _GLIBCXX_VISIBILITY(default)
73_GLIBCXX_BEGIN_NAMESPACE_VERSION
80 template<
typename _Tp>
94 explicit constexpr nullopt_t(_Construct)
noexcept { }
98 inline constexpr nullopt_t
nullopt { nullopt_t::_Construct::_Token };
100 template<
typename _Fn>
struct _Optional_func { _Fn& _M_f; };
107 class bad_optional_access :
public exception
110 bad_optional_access() =
default;
111 virtual ~bad_optional_access() =
default;
113#if __cpp_lib_constexpr_exceptions >= 202502L
116 const char* what() const noexcept
override
117 {
return "bad optional access"; }
122#if __cpp_lib_constexpr_exceptions >= 202502L
128 __throw_bad_optional_access()
129 { _GLIBCXX_THROW_OR_ABORT(bad_optional_access()); }
133 template <
typename _Tp>
134 struct _Optional_payload_base
136 using _Stored_type = remove_const_t<_Tp>;
138 _Optional_payload_base() =
default;
139 ~_Optional_payload_base() =
default;
141 template<
typename... _Args>
143 _Optional_payload_base(in_place_t __tag, _Args&&... __args)
144 : _M_payload(__tag, std::
forward<_Args>(__args)...),
148 template<
typename _Up,
typename... _Args>
150 _Optional_payload_base(std::initializer_list<_Up> __il,
152 : _M_payload(__il, std::
forward<_Args>(__args)...),
159 _Optional_payload_base(
bool ,
160 const _Optional_payload_base& __other)
162 if (__other._M_engaged)
163 this->_M_construct(__other._M_get());
169 _Optional_payload_base(
bool ,
170 _Optional_payload_base&& __other)
172 if (__other._M_engaged)
173 this->_M_construct(
std::move(__other._M_get()));
178 _Optional_payload_base(
const _Optional_payload_base&) =
default;
182 _Optional_payload_base(_Optional_payload_base&&) =
default;
184 _Optional_payload_base&
185 operator=(
const _Optional_payload_base&) =
default;
187 _Optional_payload_base&
188 operator=(_Optional_payload_base&&) =
default;
192 _M_copy_assign(
const _Optional_payload_base& __other)
194 if (this->_M_engaged && __other._M_engaged)
195 this->_M_get() = __other._M_get();
198 if (__other._M_engaged)
199 this->_M_construct(__other._M_get());
207 _M_move_assign(_Optional_payload_base&& __other)
208 noexcept(__and_v<is_nothrow_move_constructible<_Tp>,
209 is_nothrow_move_assignable<_Tp>>)
211 if (this->_M_engaged && __other._M_engaged)
212 this->_M_get() =
std::move(__other._M_get());
215 if (__other._M_engaged)
216 this->_M_construct(
std::move(__other._M_get()));
222 struct _Empty_byte { };
224 template<
typename _Up,
bool = is_trivially_destructible_v<_Up>>
227 constexpr _Storage() noexcept : _M_empty() { }
229 template<
typename... _Args>
231 _Storage(in_place_t, _Args&&... __args)
232 : _M_value(std::
forward<_Args>(__args)...)
235 template<
typename _Vp,
typename... _Args>
237 _Storage(std::initializer_list<_Vp> __il, _Args&&... __args)
238 : _M_value(__il, std::
forward<_Args>(__args)...)
241#if __cplusplus >= 202002L
242 template<
typename _Fn,
typename _Arg>
244 _Storage(_Optional_func<_Fn> __f, _Arg&& __arg)
250#if __cpp_concepts >= 202002L
251 ~_Storage() =
default;
255 ~_Storage()
requires (!is_trivially_destructible_v<_Up>)
258 _Storage(
const _Storage&) =
default;
259 _Storage(_Storage&&) =
default;
260 _Storage& operator=(
const _Storage&) =
default;
261 _Storage& operator=(_Storage&&) =
default;
264 _Empty_byte _M_empty;
268#if __cpp_concepts < 202002L
269 template<
typename _Up>
270 union _Storage<_Up, false>
272 constexpr _Storage() noexcept : _M_empty() { }
274 template<
typename... _Args>
276 _Storage(in_place_t, _Args&&... __args)
277 : _M_value(std::
forward<_Args>(__args)...)
280 template<
typename _Vp,
typename... _Args>
282 _Storage(std::initializer_list<_Vp> __il, _Args&&... __args)
283 : _M_value(__il, std::
forward<_Args>(__args)...)
286#if __cplusplus >= 202002L
287 template<
typename _Fn,
typename _Arg>
289 _Storage(_Optional_func<_Fn> __f, _Arg&& __arg)
296 _GLIBCXX20_CONSTEXPR ~_Storage() { }
298 _Storage(
const _Storage&) =
default;
299 _Storage(_Storage&&) =
default;
300 _Storage& operator=(
const _Storage&) =
default;
301 _Storage& operator=(_Storage&&) =
default;
303 _Empty_byte _M_empty;
308 _Storage<_Stored_type> _M_payload;
310 bool _M_engaged =
false;
312 template<
typename... _Args>
314 _M_construct(_Args&&... __args)
315 noexcept(is_nothrow_constructible_v<_Stored_type, _Args...>)
319 this->_M_engaged =
true;
323 _M_destroy() noexcept
326 _M_payload._M_value.~_Stored_type();
327#if defined(__clang__) && __cpp_lib_optional >= 202106L
328 if (std::is_constant_evaluated())
334#if __cplusplus >= 202002L
335 template<
typename _Fn,
typename _Up>
337 _M_apply(_Optional_func<_Fn> __f, _Up&& __x)
351 {
return this->_M_payload._M_value; }
354 _M_get() const noexcept
355 {
return this->_M_payload._M_value; }
361 if (this->_M_engaged)
364 this->_M_engaged =
false;
369 template <
typename _Tp,
371 is_trivially_destructible_v<_Tp>,
373 is_trivially_copy_assignable_v<_Tp>
374 && is_trivially_copy_constructible_v<_Tp>,
376 is_trivially_move_assignable_v<_Tp>
377 && is_trivially_move_constructible_v<_Tp>>
378 struct _Optional_payload;
381 template <
typename _Tp>
382 struct _Optional_payload<_Tp, true, true, true>
383 : _Optional_payload_base<_Tp>
385 using _Optional_payload_base<_Tp>::_Optional_payload_base;
387 _Optional_payload() =
default;
391 template <
typename _Tp>
392 struct _Optional_payload<_Tp, true, false, true>
393 : _Optional_payload_base<_Tp>
395 using _Optional_payload_base<_Tp>::_Optional_payload_base;
397 _Optional_payload() =
default;
398 ~_Optional_payload() =
default;
399 _Optional_payload(
const _Optional_payload&) =
default;
400 _Optional_payload(_Optional_payload&&) =
default;
401 _Optional_payload& operator=(_Optional_payload&&) =
default;
406 operator=(
const _Optional_payload& __other)
408 this->_M_copy_assign(__other);
414 template <
typename _Tp>
415 struct _Optional_payload<_Tp, true, true, false>
416 : _Optional_payload_base<_Tp>
418 using _Optional_payload_base<_Tp>::_Optional_payload_base;
420 _Optional_payload() =
default;
421 ~_Optional_payload() =
default;
422 _Optional_payload(
const _Optional_payload&) =
default;
423 _Optional_payload(_Optional_payload&&) =
default;
424 _Optional_payload& operator=(
const _Optional_payload&) =
default;
429 operator=(_Optional_payload&& __other)
430 noexcept(__and_v<is_nothrow_move_constructible<_Tp>,
431 is_nothrow_move_assignable<_Tp>>)
433 this->_M_move_assign(
std::move(__other));
439 template <
typename _Tp>
440 struct _Optional_payload<_Tp, true, false, false>
441 : _Optional_payload_base<_Tp>
443 using _Optional_payload_base<_Tp>::_Optional_payload_base;
445 _Optional_payload() =
default;
446 ~_Optional_payload() =
default;
447 _Optional_payload(
const _Optional_payload&) =
default;
448 _Optional_payload(_Optional_payload&&) =
default;
453 operator=(
const _Optional_payload& __other)
455 this->_M_copy_assign(__other);
462 operator=(_Optional_payload&& __other)
463 noexcept(__and_v<is_nothrow_move_constructible<_Tp>,
464 is_nothrow_move_assignable<_Tp>>)
466 this->_M_move_assign(
std::move(__other));
472 template <
typename _Tp,
bool _Copy,
bool _Move>
473 struct _Optional_payload<_Tp, false, _Copy, _Move>
474 : _Optional_payload<_Tp, true, false, false>
477 using _Optional_payload<_Tp,
true,
false,
false>::_Optional_payload;
478 _Optional_payload() =
default;
479 _Optional_payload(
const _Optional_payload&) =
default;
480 _Optional_payload(_Optional_payload&&) =
default;
481 _Optional_payload& operator=(
const _Optional_payload&) =
default;
482 _Optional_payload& operator=(_Optional_payload&&) =
default;
485 _GLIBCXX20_CONSTEXPR ~_Optional_payload() { this->_M_reset(); }
506 template<
typename _Tp,
507 bool = is_trivially_copy_constructible_v<_Tp>,
508 bool = is_trivially_move_constructible_v<_Tp>>
509 struct _Optional_base
512 constexpr _Optional_base() =
default;
515 template<
typename... _Args,
516 enable_if_t<is_constructible_v<_Tp, _Args...>,
bool> =
false>
518 _Optional_base(in_place_t, _Args&&... __args)
519 : _M_payload(in_place, std::
forward<_Args>(__args)...)
522 template<
typename _Up,
typename... _Args,
524 initializer_list<_Up>&,
525 _Args...>,
bool> =
false>
527 _Optional_base(in_place_t,
528 initializer_list<_Up> __il,
530 : _M_payload(in_place, __il, std::
forward<_Args>(__args)...)
535 _Optional_base(
const _Optional_base& __other)
536 noexcept(is_nothrow_copy_constructible_v<_Tp>)
537 : _M_payload(__other._M_payload._M_engaged, __other._M_payload)
541 _Optional_base(_Optional_base&& __other)
542 noexcept(is_nothrow_move_constructible_v<_Tp>)
543 : _M_payload(__other._M_payload._M_engaged,
544 std::move(__other._M_payload))
547#if __cpp_concepts >= 202002L
550 constexpr _Optional_base(
const _Optional_base&)
551 requires is_trivially_copy_constructible_v<_Tp> =
default;
553 constexpr _Optional_base(_Optional_base&&)
554 requires is_trivially_move_constructible_v<_Tp> = default;
558 _Optional_base& operator=(
const _Optional_base&) =
default;
559 _Optional_base& operator=(_Optional_base&&) =
default;
561 _Optional_payload<_Tp> _M_payload;
565 using _Stored_type = remove_const_t<_Tp>;
569 template<
typename... _Args>
571 _M_construct(_Args&&... __args)
572 noexcept(is_nothrow_constructible_v<_Stored_type, _Args...>)
578 _M_destruct() noexcept
579 { _M_payload._M_destroy(); }
584 { _M_payload._M_reset(); }
586 constexpr bool _M_is_engaged() const noexcept
587 {
return _M_payload._M_engaged; }
592 {
return _M_payload._M_get(); }
595 _M_get() const noexcept
596 {
return _M_payload._M_get(); }
599#if __cpp_concepts < 202002L
610 template<
typename _Tp,
typename _Dp>
611 class _Optional_base_impl
614 using _Stored_type = remove_const_t<_Tp>;
618 template<
typename... _Args>
620 _M_construct(_Args&&... __args)
621 noexcept(is_nothrow_constructible_v<_Stored_type, _Args...>)
623 static_cast<_Dp*
>(
this)->_M_payload._M_construct(
628 _M_destruct() noexcept
629 {
static_cast<_Dp*
>(
this)->_M_payload._M_destroy(); }
634 {
static_cast<_Dp*
>(
this)->_M_payload._M_reset(); }
636 constexpr bool _M_is_engaged() const noexcept
637 {
return static_cast<const _Dp*
>(
this)->_M_payload._M_engaged; }
642 {
return static_cast<_Dp*
>(
this)->_M_payload._M_get(); }
645 _M_get() const noexcept
646 {
return static_cast<const _Dp*
>(
this)->_M_payload._M_get(); }
649 template<
typename _Tp>
650 struct _Optional_base<_Tp, false, true>
651 : _Optional_base_impl<_Tp, _Optional_base<_Tp>>
654 constexpr _Optional_base() =
default;
657 template<
typename... _Args,
658 enable_if_t<is_constructible_v<_Tp, _Args...>,
bool> =
false>
660 _Optional_base(in_place_t, _Args&&... __args)
661 : _M_payload(in_place, std::
forward<_Args>(__args)...)
664 template<
typename _Up,
typename... _Args,
666 initializer_list<_Up>&,
667 _Args...>,
bool> =
false>
669 _Optional_base(in_place_t,
670 initializer_list<_Up> __il,
672 : _M_payload(in_place, __il, std::
forward<_Args>(__args)...)
676 constexpr _Optional_base(
const _Optional_base& __other)
677 : _M_payload(__other._M_payload._M_engaged, __other._M_payload)
680 constexpr _Optional_base(_Optional_base&& __other) =
default;
683 _Optional_base& operator=(
const _Optional_base&) =
default;
684 _Optional_base& operator=(_Optional_base&&) =
default;
686 _Optional_payload<_Tp> _M_payload;
689 template<
typename _Tp>
690 struct _Optional_base<_Tp, true, false>
691 : _Optional_base_impl<_Tp, _Optional_base<_Tp>>
694 constexpr _Optional_base() =
default;
697 template<
typename... _Args,
698 enable_if_t<is_constructible_v<_Tp, _Args...>,
bool> =
false>
700 _Optional_base(in_place_t, _Args&&... __args)
701 : _M_payload(in_place, std::
forward<_Args>(__args)...)
704 template<
typename _Up,
typename... _Args,
707 _Args...>,
bool> =
false>
709 _Optional_base(in_place_t,
712 : _M_payload(in_place, __il, std::
forward<_Args>(__args)...)
716 constexpr _Optional_base(
const _Optional_base& __other) =
default;
719 _Optional_base(_Optional_base&& __other)
720 noexcept(is_nothrow_move_constructible_v<_Tp>)
721 : _M_payload(__other._M_payload._M_engaged,
722 std::
move(__other._M_payload))
726 _Optional_base& operator=(
const _Optional_base&) =
default;
727 _Optional_base& operator=(_Optional_base&&) =
default;
729 _Optional_payload<_Tp> _M_payload;
732 template<
typename _Tp>
733 struct _Optional_base<_Tp, true, true>
734 : _Optional_base_impl<_Tp, _Optional_base<_Tp>>
737 constexpr _Optional_base() =
default;
740 template<
typename... _Args,
741 enable_if_t<is_constructible_v<_Tp, _Args...>,
bool> =
false>
743 _Optional_base(in_place_t, _Args&&... __args)
744 : _M_payload(in_place, std::
forward<_Args>(__args)...)
747 template<
typename _Up,
typename... _Args,
750 _Args...>,
bool> =
false>
752 _Optional_base(in_place_t,
755 : _M_payload(in_place, __il, std::
forward<_Args>(__args)...)
759 constexpr _Optional_base(
const _Optional_base& __other) =
default;
760 constexpr _Optional_base(_Optional_base&& __other) =
default;
763 _Optional_base& operator=(
const _Optional_base&) =
default;
764 _Optional_base& operator=(_Optional_base&&) =
default;
766 _Optional_payload<_Tp> _M_payload;
770 template<
typename _Tp>
771 inline constexpr bool __is_optional_v =
false;
772 template<
typename _Tp>
773 inline constexpr bool __is_optional_v<optional<_Tp>> =
true;
775 template<
typename _Tp,
typename _Wp>
776 using __converts_from_any_cvref = __or_<
783 template<
typename _Tp,
typename _Up>
784 using __converts_from_optional
785 = __converts_from_any_cvref<_Tp, optional<_Up>>;
787 template<
typename _Tp,
typename _Up>
788 using __assigns_from_optional =
789 __or_<is_assignable<_Tp&, const optional<_Up>&>,
794#if __cpp_concepts && __cpp_conditional_explicit && __glibcxx_remove_cvref
795# define _GLIBCXX_USE_CONSTRAINTS_FOR_OPTIONAL 1
798 template<
typename _Tp>
799 inline constexpr bool __is_valid_contained_type_for_optional =
801#if __cpp_lib_optional >= 202506L
802 is_lvalue_reference_v<_Tp> ||
804 (is_object_v<_Tp> && is_destructible_v<_Tp> && !is_array_v<_Tp>)
812 template<
typename _Tp>
814 :
private _Optional_base<_Tp>,
815 private _Enable_copy_move<
817 is_copy_constructible_v<_Tp>,
819 __and_v<is_copy_constructible<_Tp>, is_copy_assignable<_Tp>>,
821 is_move_constructible_v<_Tp>,
823 __and_v<is_move_constructible<_Tp>, is_move_assignable<_Tp>>,
827 static_assert(__is_valid_contained_type_for_optional<_Tp>);
830 using _Base = _Optional_base<_Tp>;
838#ifdef _GLIBCXX_USE_CONSTRAINTS_FOR_OPTIONAL
839 template<
typename _From,
typename = remove_cv_t<_Tp>>
840 static constexpr bool __not_constructing_bool_from_optional
845 template<
typename _From>
846 static constexpr bool
847 __not_constructing_bool_from_optional<_From, bool>
848 = !__is_optional_v<remove_cvref_t<_From>>;
854 template<
typename _From,
typename = remove_cv_t<_Tp>>
855 static constexpr bool __construct_from_contained_value
856 = !__converts_from_optional<_Tp, _From>::value;
860 template<
typename _From>
861 static constexpr bool __construct_from_contained_value<_From, bool>
864 template<
typename _From,
typename = remove_cv_t<_Tp>>
865 struct __not_constructing_bool_from_optional
869 template<
typename _From>
870 struct __not_constructing_bool_from_optional<_From, bool>
871 : bool_constant<!__is_optional_v<__remove_cvref_t<_From>>>
874 template<
typename _From,
typename = remove_cv_t<_Tp>>
875 struct __construct_from_contained_value
876 : __not_<__converts_from_optional<_Tp, _From>>
879 template<
typename _From>
880 struct __construct_from_contained_value<_From, bool>
884 template<
typename _Up>
885 using __not_self = __not_<is_same<optional, __remove_cvref_t<_Up>>>;
886 template<
typename _Up>
887 using __not_tag = __not_<is_same<in_place_t, __remove_cvref_t<_Up>>>;
888 template<
typename... _Cond>
889 using _Requires =
enable_if_t<__and_v<_Cond...>,
bool>;
893 using value_type = _Tp;
894#ifdef __cpp_lib_optional_range_support
895 using iterator = __gnu_cxx::__normal_iterator<_Tp*, optional>;
896 using const_iterator = __gnu_cxx::__normal_iterator<const _Tp*, optional>;
899 constexpr optional() noexcept { }
901 constexpr optional(nullopt_t)
noexcept { }
904#ifdef _GLIBCXX_USE_CONSTRAINTS_FOR_OPTIONAL
905 template<
typename _Up = remove_cv_t<_Tp>>
906 requires (!is_same_v<optional, remove_cvref_t<_Up>>)
907 && (!is_same_v<in_place_t, remove_cvref_t<_Up>>)
908 && is_constructible_v<_Tp, _Up>
909 && __not_constructing_bool_from_optional<_Up>
910 constexpr explicit(!is_convertible_v<_Up, _Tp>)
912 noexcept(is_nothrow_constructible_v<_Tp, _Up>)
913 : _Base(std::in_place, std::
forward<_Up>(__t)) { }
915 template<
typename _Up>
916 requires (!is_same_v<_Tp, _Up>)
917 && is_constructible_v<_Tp, const _Up&>
918 && __construct_from_contained_value<_Up>
919 constexpr explicit(!is_convertible_v<const _Up&, _Tp>)
920 optional(
const optional<_Up>& __t)
921 noexcept(is_nothrow_constructible_v<_Tp, const _Up&>)
924 emplace(__t._M_fwd());
927 template<
typename _Up>
928 requires (!is_same_v<_Tp, _Up>)
929 && is_constructible_v<_Tp, _Up>
930 && __construct_from_contained_value<_Up>
931 constexpr explicit(!is_convertible_v<_Up, _Tp>)
932 optional(optional<_Up>&& __t)
933 noexcept(is_nothrow_constructible_v<_Tp, _Up>)
939 template<
typename... _Args>
940 requires is_constructible_v<_Tp, _Args...>
942 optional(in_place_t, _Args&&... __args)
943 noexcept(is_nothrow_constructible_v<_Tp, _Args...>)
944 : _Base(std::in_place, std::
forward<_Args>(__args)...)
947 template<
typename _Up,
typename... _Args>
948 requires is_constructible_v<_Tp, initializer_list<_Up>&, _Args...>
950 optional(in_place_t, initializer_list<_Up> __il, _Args&&... __args)
951 noexcept(is_nothrow_constructible_v<_Tp, initializer_list<_Up>&,
953 : _Base(std::in_place, __il, std::
forward<_Args>(__args)...)
956 template<
typename _Up = remove_cv_t<_Tp>,
957 _Requires<__not_self<_Up>, __not_tag<_Up>,
958 is_constructible<_Tp, _Up>,
959 is_convertible<_Up, _Tp>,
960 __not_constructing_
bool_from_optional<_Up>> = true>
963 noexcept(is_nothrow_constructible_v<_Tp, _Up>)
964 : _Base(std::in_place, std::
forward<_Up>(__t)) { }
966 template<
typename _Up = remove_cv_t<_Tp>,
967 _Requires<__not_self<_Up>, __not_tag<_Up>,
968 is_constructible<_Tp, _Up>,
969 __not_<is_convertible<_Up, _Tp>>,
970 __not_constructing_
bool_from_optional<_Up>> = false>
973 noexcept(is_nothrow_constructible_v<_Tp, _Up>)
974 : _Base(std::in_place, std::
forward<_Up>(__t)) { }
976 template<
typename _Up,
977 _Requires<__not_<is_same<_Tp, _Up>>,
978 is_constructible<_Tp, const _Up&>,
979 is_convertible<const _Up&, _Tp>,
980 __construct_from_contained_value<_Up>> =
true>
982 optional(
const optional<_Up>& __t)
983 noexcept(is_nothrow_constructible_v<_Tp, const _Up&>)
986 emplace(__t._M_fwd());
989 template<
typename _Up,
990 _Requires<__not_<is_same<_Tp, _Up>>,
991 is_constructible<_Tp, const _Up&>,
992 __not_<is_convertible<const _Up&, _Tp>>,
993 __construct_from_contained_value<_Up>> =
false>
995 optional(
const optional<_Up>& __t)
996 noexcept(is_nothrow_constructible_v<_Tp, const _Up&>)
999 emplace(__t._M_fwd());
1002 template<
typename _Up,
1003 _Requires<__not_<is_same<_Tp, _Up>>,
1004 is_constructible<_Tp, _Up>,
1005 is_convertible<_Up, _Tp>,
1006 __construct_from_contained_value<_Up>> =
true>
1008 optional(optional<_Up>&& __t)
1009 noexcept(is_nothrow_constructible_v<_Tp, _Up>)
1015 template<
typename _Up,
1016 _Requires<__not_<is_same<_Tp, _Up>>,
1017 is_constructible<_Tp, _Up>,
1018 __not_<is_convertible<_Up, _Tp>>,
1019 __construct_from_contained_value<_Up>> =
false>
1021 optional(optional<_Up>&& __t)
1022 noexcept(is_nothrow_constructible_v<_Tp, _Up>)
1028 template<
typename... _Args,
1029 _Requires<is_constructible<_Tp, _Args...>> =
false>
1031 optional(in_place_t, _Args&&... __args)
1032 noexcept(is_nothrow_constructible_v<_Tp, _Args...>)
1033 : _Base(std::in_place, std::
forward<_Args>(__args)...) { }
1035 template<
typename _Up,
typename... _Args,
1036 _Requires<is_constructible<_Tp,
1037 initializer_list<_Up>&,
1040 optional(in_place_t, initializer_list<_Up> __il, _Args&&... __args)
1041 noexcept(is_nothrow_constructible_v<_Tp, initializer_list<_Up>&,
1043 : _Base(std::in_place, __il, std::
forward<_Args>(__args)...) { }
1047 _GLIBCXX20_CONSTEXPR optional&
1048 operator=(nullopt_t)
noexcept
1054 template<
typename _Up = remove_cv_t<_Tp>>
1055#ifdef _GLIBCXX_USE_CONSTRAINTS_FOR_OPTIONAL
1056 requires (!is_same_v<optional, remove_cvref_t<_Up>>)
1057 && (!(is_scalar_v<_Tp> && is_same_v<_Tp,
decay_t<_Up>>))
1058 && is_constructible_v<_Tp, _Up>
1059 && is_assignable_v<_Tp&, _Up>
1063 __not_<__and_<is_scalar<_Tp>,
1064 is_same<_Tp, decay_t<_Up>>>>,
1065 is_constructible<_Tp, _Up>,
1066 is_assignable<_Tp&, _Up>>,
1069 operator=(_Up&& __u)
1070 noexcept(__and_v<is_nothrow_constructible<_Tp, _Up>,
1071 is_nothrow_assignable<_Tp&, _Up>>)
1073 if (this->_M_is_engaged())
1081 template<
typename _Up>
1082#ifdef _GLIBCXX_USE_CONSTRAINTS_FOR_OPTIONAL
1083 requires (!is_same_v<_Tp, _Up>)
1084 && is_constructible_v<_Tp, const _Up&>
1085 && is_assignable_v<_Tp&, const _Up&>
1086 && (!__converts_from_optional<_Tp, _Up>::value)
1087 && (!__assigns_from_optional<_Tp, _Up>::value)
1091 is_constructible<_Tp, const _Up&>,
1092 is_assignable<_Tp&, const _Up&>,
1093 __not_<__converts_from_optional<_Tp, _Up>>,
1094 __not_<__assigns_from_optional<_Tp, _Up>>>,
1097 operator=(
const optional<_Up>& __u)
1098 noexcept(__and_v<is_nothrow_constructible<_Tp, const _Up&>,
1099 is_nothrow_assignable<_Tp&, const _Up&>>)
1103 if (this->_M_is_engaged())
1104 this->_M_get() = __u._M_fwd();
1106 this->_M_construct(__u._M_fwd());
1115 template<
typename _Up>
1116#ifdef _GLIBCXX_USE_CONSTRAINTS_FOR_OPTIONAL
1117 requires (!is_same_v<_Tp, _Up>)
1118 && is_constructible_v<_Tp, _Up>
1119 && is_assignable_v<_Tp&, _Up>
1120 && (!__converts_from_optional<_Tp, _Up>::value)
1121 && (!__assigns_from_optional<_Tp, _Up>::value)
1125 is_constructible<_Tp, _Up>,
1126 is_assignable<_Tp&, _Up>,
1127 __not_<__converts_from_optional<_Tp, _Up>>,
1128 __not_<__assigns_from_optional<_Tp, _Up>>>,
1131 operator=(optional<_Up>&& __u)
1132 noexcept(__and_v<is_nothrow_constructible<_Tp, _Up>,
1133 is_nothrow_assignable<_Tp&, _Up>>)
1137 if (this->_M_is_engaged())
1138 this->_M_get() =
std::move(__u)._M_fwd();
1140 this->_M_construct(
std::move(__u)._M_fwd());
1152 template<
typename... _Args>
1153 _GLIBCXX20_CONSTEXPR
1154 enable_if_t<is_constructible_v<_Tp, _Args...>, _Tp&>
1155 emplace(_Args&&... __args)
1156 noexcept(is_nothrow_constructible_v<_Tp, _Args...>)
1160 return this->_M_get();
1163 template<
typename _Up,
typename... _Args>
1164 _GLIBCXX20_CONSTEXPR
1167 emplace(initializer_list<_Up> __il, _Args&&... __args)
1168 noexcept(is_nothrow_constructible_v<_Tp, initializer_list<_Up>&,
1173 return this->_M_get();
1179 _GLIBCXX20_CONSTEXPR
void
1180 swap(optional& __other)
1181 noexcept(is_nothrow_move_constructible_v<_Tp>
1182 && is_nothrow_swappable_v<_Tp>)
1186 if (this->_M_is_engaged() && __other._M_is_engaged())
1187 swap(this->_M_get(), __other._M_get());
1188 else if (this->_M_is_engaged())
1190 __other._M_construct(
std::move(this->_M_get()));
1191 this->_M_destruct();
1193 else if (__other._M_is_engaged())
1195 this->_M_construct(
std::move(__other._M_get()));
1196 __other._M_destruct();
1200#ifdef __cpp_lib_optional_range_support
1202 constexpr iterator
begin() noexcept
1209 constexpr const_iterator
begin() const noexcept
1211 return const_iterator(
1216 constexpr iterator
end() noexcept
1218 return begin() + has_value();
1221 constexpr const_iterator
end() const noexcept
1223 return begin() + has_value();
1228 constexpr const _Tp*
1229 operator->() const noexcept
1231 __glibcxx_assert(this->_M_is_engaged());
1236 operator->() noexcept
1238 __glibcxx_assert(this->_M_is_engaged());
1242 constexpr const _Tp&
1245 __glibcxx_assert(this->_M_is_engaged());
1246 return this->_M_get();
1252 __glibcxx_assert(this->_M_is_engaged());
1253 return this->_M_get();
1259 __glibcxx_assert(this->_M_is_engaged());
1263 constexpr const _Tp&&
1266 __glibcxx_assert(this->_M_is_engaged());
1270 constexpr explicit operator bool() const noexcept
1271 {
return this->_M_is_engaged(); }
1273 constexpr bool has_value() const noexcept
1274 {
return this->_M_is_engaged(); }
1276 constexpr const _Tp&
1279 if (this->_M_is_engaged())
1280 return this->_M_get();
1281 __throw_bad_optional_access();
1287 if (this->_M_is_engaged())
1288 return this->_M_get();
1289 __throw_bad_optional_access();
1295 if (this->_M_is_engaged())
1297 __throw_bad_optional_access();
1300 constexpr const _Tp&&
1303 if (this->_M_is_engaged())
1305 __throw_bad_optional_access();
1310 template<
typename _Up = remove_cv_t<_Tp>>
1311 constexpr remove_cv_t<_Tp>
1312 value_or(_Up&& __u)
const&
1314 using _Xp = remove_cv_t<_Tp>;
1315 static_assert(is_convertible_v<const _Tp&, _Xp>);
1316 static_assert(is_convertible_v<_Up, _Xp>);
1318 if (this->_M_is_engaged())
1319 return this->_M_get();
1323 template<
typename _Up = remove_cv_t<_Tp>>
1324 constexpr remove_cv_t<_Tp>
1325 value_or(_Up&& __u) &&
1327 using _Xp = remove_cv_t<_Tp>;
1328 static_assert(is_convertible_v<_Tp, _Xp>);
1329 static_assert(is_convertible_v<_Up, _Xp>);
1331 if (this->_M_is_engaged())
1336#if __cpp_lib_optional >= 202110L
1339 template<
typename _Fn>
1341 and_then(_Fn&& __f) &
1343 using _Up = remove_cvref_t<invoke_result_t<_Fn, _Tp&>>;
1344 static_assert(__is_optional_v<_Up>,
1345 "the function passed to std::optional<T>::and_then "
1346 "must return a std::optional");
1353 template<
typename _Fn>
1355 and_then(_Fn&& __f)
const &
1357 using _Up = remove_cvref_t<invoke_result_t<_Fn, const _Tp&>>;
1358 static_assert(__is_optional_v<_Up>,
1359 "the function passed to std::optional<T>::and_then "
1360 "must return a std::optional");
1367 template<
typename _Fn>
1369 and_then(_Fn&& __f) &&
1371 using _Up = remove_cvref_t<invoke_result_t<_Fn, _Tp>>;
1372 static_assert(__is_optional_v<_Up>,
1373 "the function passed to std::optional<T>::and_then "
1374 "must return a std::optional");
1381 template<
typename _Fn>
1383 and_then(_Fn&& __f)
const &&
1385 using _Up = remove_cvref_t<invoke_result_t<_Fn, const _Tp>>;
1386 static_assert(__is_optional_v<_Up>,
1387 "the function passed to std::optional<T>::and_then "
1388 "must return a std::optional");
1395 template<
typename _Fn>
1397 transform(_Fn&& __f) &
1399 using _Up = remove_cv_t<invoke_result_t<_Fn, _Tp&>>;
1401 return optional<_Up>(_Optional_func<_Fn>{__f}, _M_get());
1403 return optional<_Up>();
1406 template<
typename _Fn>
1408 transform(_Fn&& __f)
const &
1410 using _Up = remove_cv_t<invoke_result_t<_Fn, const _Tp&>>;
1412 return optional<_Up>(_Optional_func<_Fn>{__f}, _M_get());
1414 return optional<_Up>();
1417 template<
typename _Fn>
1419 transform(_Fn&& __f) &&
1421 using _Up = remove_cv_t<invoke_result_t<_Fn, _Tp>>;
1423 return optional<_Up>(_Optional_func<_Fn>{__f},
std::move(_M_get()));
1425 return optional<_Up>();
1428 template<
typename _Fn>
1430 transform(_Fn&& __f)
const &&
1432 using _Up = remove_cv_t<invoke_result_t<_Fn, const _Tp>>;
1434 return optional<_Up>(_Optional_func<_Fn>{__f},
std::move(_M_get()));
1436 return optional<_Up>();
1439 template<
typename _Fn>
requires invocable<_Fn> && copy_constructible<_Tp>
1441 or_else(_Fn&& __f)
const&
1443 using _Up = invoke_result_t<_Fn>;
1444 static_assert(is_same_v<remove_cvref_t<_Up>, optional>,
1445 "the function passed to std::optional<T>::or_else "
1446 "must return a std::optional<T>");
1454 template<
typename _Fn>
requires invocable<_Fn> && move_constructible<_Tp>
1456 or_else(_Fn&& __f) &&
1458 using _Up = invoke_result_t<_Fn>;
1459 static_assert(is_same_v<remove_cvref_t<_Up>, optional>,
1460 "the function passed to std::optional<T>::or_else "
1461 "must return a std::optional<T>");
1470 _GLIBCXX20_CONSTEXPR
void reset() noexcept { this->_M_reset(); }
1473 using _Base::_M_get;
1475 [[__gnu__::__always_inline__]]
1478 {
return _M_get(); }
1480 [[__gnu__::__always_inline__]]
1482 _M_fwd() &&
noexcept
1485 [[__gnu__::__always_inline__]]
1486 constexpr const _Tp&
1487 _M_fwd() const& noexcept
1488 {
return _M_get(); }
1490 [[__gnu__::__always_inline__]]
1491 constexpr const _Tp&&
1492 _M_fwd() const&& noexcept
1495 template<
typename _Up>
friend class optional;
1497#if __cpp_lib_optional >= 202110L
1498 template<
typename _Fn,
typename _Value>
1500 optional(_Optional_func<_Fn> __f, _Value&& __v)
1507#if __cpp_lib_optional >= 202506L
1508 template<
typename _Tp>
1509 class optional<_Tp&>;
1511 template<
typename _Tp>
1512 constexpr bool __is_optional_ref_v =
false;
1514 template<
typename _Tp>
1515 constexpr bool __is_optional_ref_v<optional<_Tp&>> =
true;
1517 template<
typename _Tp>
1518 struct __optional_ref_base
1521#ifdef __cpp_lib_optional_range_support
1522 template<
typename _Tp>
1523 struct __optional_ref_base<_Tp[]>
1526 template<
typename _Tp>
1527 requires is_object_v<_Tp>
1528 struct __optional_ref_base<_Tp>
1530 using iterator = __gnu_cxx::__normal_iterator<_Tp*, optional<_Tp&>>;
1534 template<
typename _Tp>
1535 class optional<_Tp&> :
public __optional_ref_base<_Tp>
1537 static_assert(__is_valid_contained_type_for_optional<_Tp&>);
1543 constexpr optional() noexcept = default;
1544 constexpr optional(nullopt_t) noexcept : optional() {}
1545 constexpr optional(
const optional&)
noexcept =
default;
1547 template<
typename _Arg>
1548 requires is_constructible_v<_Tp&, _Arg>
1549 && (!reference_constructs_from_temporary_v<_Tp&, _Arg>)
1551 optional(in_place_t, _Arg&& __arg)
1556 template<
typename _Up>
1557 requires (!is_same_v<remove_cvref_t<_Up>, optional>)
1558 && (!is_same_v<remove_cvref_t<_Up>, in_place_t>)
1559 && is_constructible_v<_Tp&, _Up>
1560 && (!reference_constructs_from_temporary_v<_Tp&, _Up>)
1561 explicit(!is_convertible_v<_Up, _Tp&>)
1564 noexcept(is_nothrow_constructible_v<_Tp&, _Up>)
1569 template<
typename _Up>
1570 requires (!is_same_v<remove_cvref_t<_Up>, optional>)
1571 && (!is_same_v<remove_cvref_t<_Up>, in_place_t>)
1572 && is_constructible_v<_Tp&, _Up>
1573 && reference_constructs_from_temporary_v<_Tp&, _Up>
1574 explicit(!is_convertible_v<_Up, _Tp&>)
1576 optional(_Up&& __u) =
delete;
1579 template<
typename _Up>
1580 requires (!is_same_v<remove_cv_t<_Tp>, optional<_Up>>)
1581 && (!is_same_v<_Tp&, _Up>)
1582 && is_constructible_v<_Tp&, _Up&>
1583 && (!reference_constructs_from_temporary_v<_Tp&, _Up&>)
1584 explicit(!is_convertible_v<_Up&, _Tp&>)
1586 optional(optional<_Up>& __rhs)
1587 noexcept(is_nothrow_constructible_v<_Tp&, _Up&>)
1590 __convert_ref_init_val(__rhs._M_fwd());
1593 template<
typename _Up>
1594 requires (!is_same_v<remove_cv_t<_Tp>, optional<_Up>>)
1595 && (!is_same_v<_Tp&, _Up>)
1596 && is_constructible_v<_Tp&, _Up&>
1597 && reference_constructs_from_temporary_v<_Tp&, _Up&>
1598 explicit(!is_convertible_v<_Up&, _Tp&>)
1600 optional(optional<_Up>& __rhs) =
delete;
1603 template<
typename _Up>
1604 requires (!is_same_v<remove_cv_t<_Tp>, optional<_Up>>)
1605 && (!is_same_v<_Tp&, _Up>)
1606 && is_constructible_v<_Tp&, const _Up&>
1607 && (!reference_constructs_from_temporary_v<_Tp&, const _Up&>)
1608 explicit(!is_convertible_v<const _Up&, _Tp&>)
1610 optional(
const optional<_Up>& __rhs)
1611 noexcept(is_nothrow_constructible_v<_Tp&, _Up&>)
1614 __convert_ref_init_val(__rhs._M_fwd());
1617 template<
typename _Up>
1618 requires (!is_same_v<remove_cv_t<_Tp>, optional<_Up>>)
1619 && (!is_same_v<_Tp&, _Up>)
1620 && is_constructible_v<_Tp&, const _Up&>
1621 && reference_constructs_from_temporary_v<_Tp&, const _Up&>
1622 explicit(!is_convertible_v<const _Up&, _Tp&>)
1624 optional(
const optional<_Up>& __rhs) =
delete;
1627 template<
typename _Up>
1628 requires (!is_same_v<remove_cv_t<_Tp>, optional<_Up>>)
1629 && (!is_same_v<_Tp&, _Up>)
1630 && is_constructible_v<_Tp&, _Up>
1631 && (!reference_constructs_from_temporary_v<_Tp&, _Up>)
1632 explicit(!is_convertible_v<_Up, _Tp&>)
1634 optional(optional<_Up>&& __rhs)
1635 noexcept(is_nothrow_constructible_v<_Tp&, _Up>)
1638 __convert_ref_init_val(
std::move(__rhs)._M_fwd());
1641 template<
typename _Up>
1642 requires (!is_same_v<remove_cv_t<_Tp>, optional<_Up>>)
1643 && (!is_same_v<_Tp&, _Up>)
1644 && is_constructible_v<_Tp&, _Up>
1645 && reference_constructs_from_temporary_v<_Tp&, _Up>
1646 explicit(!is_convertible_v<_Up, _Tp&>)
1648 optional(optional<_Up>&& __rhs) =
delete;
1651 template<
typename _Up>
1652 requires (!is_same_v<remove_cv_t<_Tp>, optional<_Up>>)
1653 && (!is_same_v<_Tp&, _Up>)
1654 && is_constructible_v<_Tp&, const _Up>
1655 && (!reference_constructs_from_temporary_v<_Tp&, _Up>)
1656 explicit(!is_convertible_v<const _Up, _Tp&>)
1658 optional(
const optional<_Up>&& __rhs)
1659 noexcept(is_nothrow_constructible_v<_Tp&, const _Up>)
1662 __convert_ref_init_val(
std::move(__rhs)._M_fwd());
1665 template<
typename _Up>
1666 requires (!is_same_v<remove_cv_t<_Tp>, optional<_Up>>)
1667 && (!is_same_v<_Tp&, _Up>)
1668 && is_constructible_v<_Tp&, const _Up>
1669 && reference_constructs_from_temporary_v<_Tp&, const _Up>
1670 explicit(!is_convertible_v<const _Up, _Tp&>)
1672 optional(
const optional<_Up>&& __rhs) =
delete;
1674 constexpr ~optional() =
default;
1677 constexpr optional& operator=(nullopt_t)
noexcept
1683 constexpr optional& operator=(
const optional&)
noexcept =
default;
1685 template<
typename _Up>
1686 requires is_constructible_v<_Tp&, _Up>
1687 && (!reference_constructs_from_temporary_v<_Tp&, _Up>)
1690 noexcept(is_nothrow_constructible_v<_Tp&, _Up>)
1699 constexpr void swap(optional& __rhs)
noexcept
1700 { std::swap(_M_val, __rhs._M_val); }
1702#ifdef __cpp_lib_optional_range_support
1704 constexpr auto begin() const noexcept
1705 requires is_object_v<_Tp> && (!is_unbounded_array_v<_Tp>)
1706 {
return __gnu_cxx::__normal_iterator<_Tp*, optional>(_M_val); }
1708 constexpr auto end() const noexcept
1709 requires is_object_v<_Tp> && (!is_unbounded_array_v<_Tp>)
1710 {
return begin() + has_value(); }
1714 constexpr _Tp* operator->() const noexcept
1716 __glibcxx_assert(_M_val);
1720 constexpr _Tp&
operator*() const noexcept
1722 __glibcxx_assert(_M_val);
1726 constexpr explicit operator bool() const noexcept
1731 constexpr bool has_value() const noexcept
1736 constexpr _Tp& value()
const
1740 __throw_bad_optional_access();
1745 template<
typename _Up = remove_cv_t<_Tp>>
1746 requires is_object_v<_Tp> && (!is_array_v<_Tp>)
1748 value_or(_Up&& __u)
const
1750 using _Xp = remove_cv_t<_Tp>;
1751 static_assert(is_convertible_v<_Tp&, _Xp>);
1752 static_assert(is_convertible_v<_Up, _Xp>);
1759 template<
typename _Fn>
1761 and_then(_Fn&& __f)
const
1763 using _Up = remove_cvref_t<invoke_result_t<_Fn, _Tp&>>;
1764 static_assert(__is_optional_v<_Up>,
1765 "the function passed to std::optional<T&>::and_then "
1766 "must return a std::optional");
1773 template<
typename _Fn>
1775 optional<remove_cv_t<invoke_result_t<_Fn, _Tp&>>>
1776 transform(_Fn&& __f)
const
1778 using _Up = remove_cv_t<invoke_result_t<_Fn, _Tp&>>;
1780 return optional<_Up>(_Optional_func<_Fn>{__f}, *_M_val);
1782 return optional<_Up>();
1785 template<
typename _Fn>
1789 or_else(_Fn&& __f)
const
1791 static_assert(is_same_v<remove_cvref_t<invoke_result_t<_Fn>>, optional>,
1792 "the function passed to std::optional<T&>::or_else "
1793 "must return a std::optional<T&>");
1803 constexpr void reset() noexcept
1809 _Tp *_M_val =
nullptr;
1811 [[__gnu__::__always_inline__]]
1813 _M_fwd() const noexcept
1816 template<
typename _Up>
friend class optional;
1818 template<
typename _Up>
1821 __convert_ref_init_val(_Up&& __u)
1828 template<
typename _Fn,
typename _Value>
1830 optional(_Optional_func<_Fn> __f, _Value&& __v)
1838 template<
typename _Tp>
1839 using __optional_relop_t =
1842 template<
typename _Tp,
typename _Up>
1843 using __optional_eq_t = __optional_relop_t<
1847 template<
typename _Tp,
typename _Up>
1848 using __optional_ne_t = __optional_relop_t<
1852 template<
typename _Tp,
typename _Up>
1853 using __optional_lt_t = __optional_relop_t<
1857 template<
typename _Tp,
typename _Up>
1858 using __optional_gt_t = __optional_relop_t<
1862 template<
typename _Tp,
typename _Up>
1863 using __optional_le_t = __optional_relop_t<
1867 template<
typename _Tp,
typename _Up>
1868 using __optional_ge_t = __optional_relop_t<
1873 template<
typename _Tp,
typename _Up>
1875 operator==(
const optional<_Tp>& __lhs,
const optional<_Up>& __rhs)
1876 -> __optional_eq_t<_Tp, _Up>
1878 if (__lhs.has_value() != __rhs.has_value())
1880 if (!__lhs.has_value())
1882 return *__lhs == *__rhs;
1885 template<
typename _Tp,
typename _Up>
1887 operator!=(
const optional<_Tp>& __lhs,
const optional<_Up>& __rhs)
1888 -> __optional_ne_t<_Tp, _Up>
1890 if (__lhs.has_value() != __rhs.has_value())
1892 if (!__lhs.has_value())
1894 return *__lhs != *__rhs;
1897 template<
typename _Tp,
typename _Up>
1899 operator<(
const optional<_Tp>& __lhs,
const optional<_Up>& __rhs)
1900 -> __optional_lt_t<_Tp, _Up>
1902 if (!__rhs.has_value())
1904 if (!__lhs.has_value())
1906 return *__lhs < *__rhs;
1909 template<
typename _Tp,
typename _Up>
1911 operator>(
const optional<_Tp>& __lhs,
const optional<_Up>& __rhs)
1912 -> __optional_gt_t<_Tp, _Up>
1914 if (!__lhs.has_value())
1916 if (!__rhs.has_value())
1918 return *__lhs > *__rhs;
1921 template<
typename _Tp,
typename _Up>
1923 operator<=(
const optional<_Tp>& __lhs,
const optional<_Up>& __rhs)
1924 -> __optional_le_t<_Tp, _Up>
1926 if (!__lhs.has_value())
1928 if (!__rhs.has_value())
1930 return *__lhs <= *__rhs;
1933 template<
typename _Tp,
typename _Up>
1935 operator>=(
const optional<_Tp>& __lhs,
const optional<_Up>& __rhs)
1936 -> __optional_ge_t<_Tp, _Up>
1938 if (!__rhs.has_value())
1940 if (!__lhs.has_value())
1942 return *__lhs >= *__rhs;
1945#ifdef __cpp_lib_three_way_comparison
1946 template<
typename _Tp, three_way_comparable_with<_Tp> _Up>
1949 operator<=>(
const optional<_Tp>& __x,
const optional<_Up>& __y)
1951 return __x && __y ? *__x <=> *__y : bool(__x) <=> bool(__y);
1956 template<
typename _Tp>
1959 operator==(
const optional<_Tp>& __lhs, nullopt_t)
noexcept
1962#ifdef __cpp_lib_three_way_comparison
1963 template<
typename _Tp>
1965 constexpr strong_ordering
1966 operator<=>(
const optional<_Tp>& __x, nullopt_t)
noexcept
1967 {
return bool(__x) <=>
false; }
1969 template<
typename _Tp>
1971 operator==(nullopt_t,
const optional<_Tp>& __rhs)
noexcept
1974 template<
typename _Tp>
1976 operator!=(
const optional<_Tp>& __lhs, nullopt_t)
noexcept
1977 {
return static_cast<bool>(__lhs); }
1979 template<
typename _Tp>
1981 operator!=(nullopt_t,
const optional<_Tp>& __rhs)
noexcept
1982 {
return static_cast<bool>(__rhs); }
1984 template<
typename _Tp>
1986 operator<(
const optional<_Tp>& , nullopt_t)
noexcept
1989 template<
typename _Tp>
1991 operator<(nullopt_t,
const optional<_Tp>& __rhs)
noexcept
1992 {
return static_cast<bool>(__rhs); }
1994 template<
typename _Tp>
1996 operator>(
const optional<_Tp>& __lhs, nullopt_t)
noexcept
1997 {
return static_cast<bool>(__lhs); }
1999 template<
typename _Tp>
2001 operator>(nullopt_t,
const optional<_Tp>& )
noexcept
2004 template<
typename _Tp>
2006 operator<=(
const optional<_Tp>& __lhs, nullopt_t)
noexcept
2009 template<
typename _Tp>
2011 operator<=(nullopt_t,
const optional<_Tp>& )
noexcept
2014 template<
typename _Tp>
2016 operator>=(
const optional<_Tp>& , nullopt_t)
noexcept
2019 template<
typename _Tp>
2021 operator>=(nullopt_t,
const optional<_Tp>& __rhs)
noexcept
2025#if __cpp_lib_concepts
2028# define _REQUIRES_NOT_OPTIONAL(T) requires (!__is_optional_v<T>)
2030# define _REQUIRES_NOT_OPTIONAL(T)
2034 template<
typename _Tp,
typename _Up>
2035 _REQUIRES_NOT_OPTIONAL(_Up)
2037 operator== [[nodiscard]] (
const optional<_Tp>& __lhs,
const _Up& __rhs)
2038 -> __optional_eq_t<_Tp, _Up>
2040 if (__lhs.has_value())
2041 return *__lhs == __rhs;
2045 template<
typename _Tp,
typename _Up>
2046 _REQUIRES_NOT_OPTIONAL(_Tp)
2048 operator== [[nodiscard]] (
const _Tp& __lhs,
const optional<_Up>& __rhs)
2049 -> __optional_eq_t<_Tp, _Up>
2051 if (__rhs.has_value())
2052 return __lhs == *__rhs;
2056 template<
typename _Tp,
typename _Up>
2057 _REQUIRES_NOT_OPTIONAL(_Up)
2059 operator!= [[nodiscard]] (
const optional<_Tp>& __lhs,
const _Up& __rhs)
2060 -> __optional_ne_t<_Tp, _Up>
2062 if (__lhs.has_value())
2063 return *__lhs != __rhs;
2067 template<
typename _Tp,
typename _Up>
2068 _REQUIRES_NOT_OPTIONAL(_Tp)
2070 operator!= [[nodiscard]] (
const _Tp& __lhs,
const optional<_Up>& __rhs)
2071 -> __optional_ne_t<_Tp, _Up>
2073 if (__rhs.has_value())
2074 return __lhs != *__rhs;
2078 template<
typename _Tp,
typename _Up>
2079 _REQUIRES_NOT_OPTIONAL(_Up)
2081 operator< [[nodiscard]] (
const optional<_Tp>& __lhs,
const _Up& __rhs)
2082 -> __optional_lt_t<_Tp, _Up>
2084 if (__lhs.has_value())
2085 return *__lhs < __rhs;
2089 template<
typename _Tp,
typename _Up>
2090 _REQUIRES_NOT_OPTIONAL(_Tp)
2092 operator< [[nodiscard]] (
const _Tp& __lhs,
const optional<_Up>& __rhs)
2093 -> __optional_lt_t<_Tp, _Up>
2095 if (__rhs.has_value())
2096 return __lhs < *__rhs;
2100 template<
typename _Tp,
typename _Up>
2101 _REQUIRES_NOT_OPTIONAL(_Up)
2103 operator> [[nodiscard]] (
const optional<_Tp>& __lhs,
const _Up& __rhs)
2104 -> __optional_gt_t<_Tp, _Up>
2106 if (__lhs.has_value())
2107 return *__lhs > __rhs;
2111 template<
typename _Tp,
typename _Up>
2112 _REQUIRES_NOT_OPTIONAL(_Tp)
2114 operator> [[nodiscard]] (
const _Tp& __lhs,
const optional<_Up>& __rhs)
2115 -> __optional_gt_t<_Tp, _Up>
2117 if (__rhs.has_value())
2118 return __lhs > *__rhs;
2122 template<
typename _Tp,
typename _Up>
2123 _REQUIRES_NOT_OPTIONAL(_Up)
2125 operator<= [[nodiscard]] (
const optional<_Tp>& __lhs,
const _Up& __rhs)
2126 -> __optional_le_t<_Tp, _Up>
2128 if (__lhs.has_value())
2129 return *__lhs <= __rhs;
2133 template<
typename _Tp,
typename _Up>
2134 _REQUIRES_NOT_OPTIONAL(_Tp)
2136 operator<= [[nodiscard]] (
const _Tp& __lhs,
const optional<_Up>& __rhs)
2137 -> __optional_le_t<_Tp, _Up>
2139 if (__rhs.has_value())
2140 return __lhs <= *__rhs;
2144 template<
typename _Tp,
typename _Up>
2145 _REQUIRES_NOT_OPTIONAL(_Up)
2147 operator>= [[nodiscard]] (
const optional<_Tp>& __lhs,
const _Up& __rhs)
2148 -> __optional_ge_t<_Tp, _Up>
2150 if (__lhs.has_value())
2151 return *__lhs >= __rhs;
2155 template<
typename _Tp,
typename _Up>
2156 _REQUIRES_NOT_OPTIONAL(_Tp)
2158 operator>= [[nodiscard]] (
const _Tp& __lhs,
const optional<_Up>& __rhs)
2159 -> __optional_ge_t<_Tp, _Up>
2161 if (__rhs.has_value())
2162 return __lhs >= *__rhs;
2166#ifdef __cpp_lib_three_way_comparison
2170 template<
typename _Tp>
2171 concept __is_derived_from_optional =
requires (
const _Tp& __t) {
2172 []<
typename _Up>(
const optional<_Up>&){ }(__t);
2175 template<
typename _Tp,
typename _Up>
2176 requires (!__is_derived_from_optional<_Up>)
2178 && three_way_comparable_with<_Tp, _Up>
2180 operator<=> [[nodiscard]] (
const optional<_Tp>& __x,
const _Up& __v)
2181 {
return bool(__x) ? *__x <=> __v : strong_ordering::less; }
2188 template<
typename _Tp>
2189 _GLIBCXX20_CONSTEXPR
2191 swap(optional<_Tp>& __lhs, optional<_Tp>& __rhs)
2192 noexcept(
noexcept(__lhs.swap(__rhs)))
2193 { __lhs.swap(__rhs); }
2195#if __cpp_lib_optional >= 202506L
2198 template<
typename _Tp>
2200 swap(optional<_Tp&>& __lhs, optional<_Tp&>& __rhs)
noexcept
2201 { __lhs.swap(__rhs); }
2206 template<
typename _Tp>
2207 enable_if_t<!(is_move_constructible_v<_Tp> && is_swappable_v<_Tp>)>
2208 swap(optional<_Tp>&, optional<_Tp>&) =
delete;
2210#if __cpp_lib_optional >= 202506L
2211 template<
int = 0,
typename _Tp>
2213 template<
typename _Tp>
2217 optional<decay_t<_Tp>>>
2218 make_optional(_Tp&& __t)
2219 noexcept(is_nothrow_constructible_v<optional<decay_t<_Tp>>, _Tp>)
2222 template<
typename _Tp,
typename... _Args>
2226 make_optional(_Args&&... __args)
2227 noexcept(is_nothrow_constructible_v<_Tp, _Args...>)
2230 template<
typename _Tp,
typename _Up,
typename... _Args>
2235 noexcept(is_nothrow_constructible_v<_Tp, initializer_list<_Up>&, _Args...>)
2240 template<
typename _Tp,
typename _Up = remove_const_t<_Tp>>
2241 struct __optional_hash
2242#if ! _GLIBCXX_INLINE_VERSION
2243 :
public __hash_empty_base<_Up>
2246#if __cplusplus < 202002L
2247 using result_type [[__deprecated__]] = size_t;
2248 using argument_type [[__deprecated__]] = optional<_Tp>;
2252 operator()(
const optional<_Tp>& __t)
const
2253 noexcept(
noexcept(hash<_Up>{}(*__t)))
2257 constexpr size_t __magic_disengaged_hash =
static_cast<size_t>(-3333);
2258 return __t ? hash<_Up>{}(*__t) : __magic_disengaged_hash;
2262 template<
typename _Tp>
2263 struct hash<optional<_Tp>>
2265 :
public __conditional_t<__is_hash_enabled_for<remove_const_t<_Tp>>,
2266 __optional_hash<_Tp>,
2267 __hash_not_enabled<_Tp>>
2270 template<
typename _Tp>
2276#if __cpp_deduction_guides >= 201606
2277 template <
typename _Tp> optional(_Tp) -> optional<_Tp>;
2280#ifdef __cpp_lib_optional_range_support
2281 template<
typename _Tp>
2282 inline constexpr bool
2285#if __cpp_lib_optional >= 202506L
2286 template<
typename _Tp>
2288 ranges::enable_borrowed_range<optional<_Tp&>> =
true;
2292 template<
typename _Tp>
2293 inline constexpr range_format
2294 format_kind<optional<_Tp>> = range_format::disabled;
2298#undef _GLIBCXX_USE_CONSTRAINTS_FOR_OPTIONAL
2300_GLIBCXX_END_NAMESPACE_VERSION
constexpr bool enable_view
[range.view] The ranges::enable_view boolean.
constexpr complex< _Tp > operator*(const complex< _Tp > &__x, const complex< _Tp > &__y)
Return new complex value x times y.
__bool_constant< true > true_type
The type used as a compile-time boolean with true value.
typename remove_reference< _Tp >::type remove_reference_t
Alias template for remove_reference.
typename enable_if< _Cond, _Tp >::type enable_if_t
Alias template for enable_if.
typename decay< _Tp >::type decay_t
Alias template for decay.
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 __invoke_result< _Callable, _Args... >::type __invoke(_Callable &&__fn, _Args &&... __args) noexcept(__is_nothrow_invocable< _Callable, _Args... >::value)
Invoke a callable object.
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.
constexpr nullopt_t nullopt
Tag to disengage optional objects.
ISO C++ entities toplevel namespace is std.
constexpr auto end(_Container &__cont) noexcept(noexcept(__cont.end())) -> decltype(__cont.end())
Return an iterator pointing to one past the last element of the container.
typename __detail::__cmp3way_res_impl< _Tp, _Up >::type compare_three_way_result_t
[cmp.result], result of three-way comparison
constexpr void _Construct(_Tp *__p, _Args &&... __args)
constexpr auto begin(_Container &__cont) noexcept(noexcept(__cont.begin())) -> decltype(__cont.begin())
Return an iterator pointing to the first element of the container.
Primary class template hash.
Base class for all library exceptions.
[concept.invocable], concept invocable