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
44#ifdef __cpp_lib_optional
55#if __cplusplus > 201703L
59#if __cplusplus > 202002L
62#ifdef __cpp_lib_optional_range_support
70namespace std _GLIBCXX_VISIBILITY(default)
72_GLIBCXX_BEGIN_NAMESPACE_VERSION
79 template<
typename _Tp>
93 explicit constexpr nullopt_t(_Construct)
noexcept { }
97 inline constexpr nullopt_t
nullopt { nullopt_t::_Construct::_Token };
99 template<
typename _Fn>
struct _Optional_func { _Fn& _M_f; };
106 class bad_optional_access :
public exception
109 bad_optional_access() =
default;
110 virtual ~bad_optional_access() =
default;
112#if __cpp_lib_constexpr_exceptions >= 202502L
115 const char* what() const noexcept
override
116 {
return "bad optional access"; }
121#if __cpp_lib_constexpr_exceptions >= 202502L
127 __throw_bad_optional_access()
128 { _GLIBCXX_THROW_OR_ABORT(bad_optional_access()); }
132 template <
typename _Tp>
133 struct _Optional_payload_base
135 using _Stored_type = remove_const_t<_Tp>;
137 _Optional_payload_base() =
default;
138 ~_Optional_payload_base() =
default;
140 template<
typename... _Args>
142 _Optional_payload_base(in_place_t __tag, _Args&&... __args)
143 : _M_payload(__tag, std::
forward<_Args>(__args)...),
147 template<
typename _Up,
typename... _Args>
149 _Optional_payload_base(std::initializer_list<_Up> __il,
151 : _M_payload(__il, std::
forward<_Args>(__args)...),
158 _Optional_payload_base(
bool ,
159 const _Optional_payload_base& __other)
161 if (__other._M_engaged)
162 this->_M_construct(__other._M_get());
168 _Optional_payload_base(
bool ,
169 _Optional_payload_base&& __other)
171 if (__other._M_engaged)
172 this->_M_construct(
std::move(__other._M_get()));
177 _Optional_payload_base(
const _Optional_payload_base&) =
default;
181 _Optional_payload_base(_Optional_payload_base&&) =
default;
183 _Optional_payload_base&
184 operator=(
const _Optional_payload_base&) =
default;
186 _Optional_payload_base&
187 operator=(_Optional_payload_base&&) =
default;
191 _M_copy_assign(
const _Optional_payload_base& __other)
193 if (this->_M_engaged && __other._M_engaged)
194 this->_M_get() = __other._M_get();
197 if (__other._M_engaged)
198 this->_M_construct(__other._M_get());
206 _M_move_assign(_Optional_payload_base&& __other)
207 noexcept(__and_v<is_nothrow_move_constructible<_Tp>,
208 is_nothrow_move_assignable<_Tp>>)
210 if (this->_M_engaged && __other._M_engaged)
211 this->_M_get() =
std::move(__other._M_get());
214 if (__other._M_engaged)
215 this->_M_construct(
std::move(__other._M_get()));
221 struct _Empty_byte { };
223 template<
typename _Up,
bool = is_trivially_destructible_v<_Up>>
226 constexpr _Storage() noexcept : _M_empty() { }
228 template<
typename... _Args>
230 _Storage(in_place_t, _Args&&... __args)
231 : _M_value(std::
forward<_Args>(__args)...)
234 template<
typename _Vp,
typename... _Args>
236 _Storage(std::initializer_list<_Vp> __il, _Args&&... __args)
237 : _M_value(__il, std::
forward<_Args>(__args)...)
240#if __cplusplus >= 202002L
241 template<
typename _Fn,
typename _Arg>
243 _Storage(_Optional_func<_Fn> __f, _Arg&& __arg)
249#if __cpp_concepts >= 202002L
250 ~_Storage() =
default;
254 ~_Storage()
requires (!is_trivially_destructible_v<_Up>)
257 _Storage(
const _Storage&) =
default;
258 _Storage(_Storage&&) =
default;
259 _Storage& operator=(
const _Storage&) =
default;
260 _Storage& operator=(_Storage&&) =
default;
263 _Empty_byte _M_empty;
267#if __cpp_concepts < 202002L
268 template<
typename _Up>
269 union _Storage<_Up, false>
271 constexpr _Storage() noexcept : _M_empty() { }
273 template<
typename... _Args>
275 _Storage(in_place_t, _Args&&... __args)
276 : _M_value(std::
forward<_Args>(__args)...)
279 template<
typename _Vp,
typename... _Args>
281 _Storage(std::initializer_list<_Vp> __il, _Args&&... __args)
282 : _M_value(__il, std::
forward<_Args>(__args)...)
285#if __cplusplus >= 202002L
286 template<
typename _Fn,
typename _Arg>
288 _Storage(_Optional_func<_Fn> __f, _Arg&& __arg)
295 _GLIBCXX20_CONSTEXPR ~_Storage() { }
297 _Storage(
const _Storage&) =
default;
298 _Storage(_Storage&&) =
default;
299 _Storage& operator=(
const _Storage&) =
default;
300 _Storage& operator=(_Storage&&) =
default;
302 _Empty_byte _M_empty;
307 _Storage<_Stored_type> _M_payload;
309 bool _M_engaged =
false;
311 template<
typename... _Args>
313 _M_construct(_Args&&... __args)
314 noexcept(is_nothrow_constructible_v<_Stored_type, _Args...>)
318 this->_M_engaged =
true;
322 _M_destroy() noexcept
325 _M_payload._M_value.~_Stored_type();
326#if defined(__clang__) && __cpp_lib_optional >= 202106L
327 if (std::is_constant_evaluated())
333#if __cplusplus >= 202002L
334 template<
typename _Fn,
typename _Up>
336 _M_apply(_Optional_func<_Fn> __f, _Up&& __x)
350 {
return this->_M_payload._M_value; }
353 _M_get() const noexcept
354 {
return this->_M_payload._M_value; }
360 if (this->_M_engaged)
363 this->_M_engaged =
false;
368 template <
typename _Tp,
370 is_trivially_destructible_v<_Tp>,
372 is_trivially_copy_assignable_v<_Tp>
373 && is_trivially_copy_constructible_v<_Tp>,
375 is_trivially_move_assignable_v<_Tp>
376 && is_trivially_move_constructible_v<_Tp>>
377 struct _Optional_payload;
380 template <
typename _Tp>
381 struct _Optional_payload<_Tp, true, true, true>
382 : _Optional_payload_base<_Tp>
384 using _Optional_payload_base<_Tp>::_Optional_payload_base;
386 _Optional_payload() =
default;
390 template <
typename _Tp>
391 struct _Optional_payload<_Tp, true, false, true>
392 : _Optional_payload_base<_Tp>
394 using _Optional_payload_base<_Tp>::_Optional_payload_base;
396 _Optional_payload() =
default;
397 ~_Optional_payload() =
default;
398 _Optional_payload(
const _Optional_payload&) =
default;
399 _Optional_payload(_Optional_payload&&) =
default;
400 _Optional_payload& operator=(_Optional_payload&&) =
default;
405 operator=(
const _Optional_payload& __other)
407 this->_M_copy_assign(__other);
413 template <
typename _Tp>
414 struct _Optional_payload<_Tp, true, true, false>
415 : _Optional_payload_base<_Tp>
417 using _Optional_payload_base<_Tp>::_Optional_payload_base;
419 _Optional_payload() =
default;
420 ~_Optional_payload() =
default;
421 _Optional_payload(
const _Optional_payload&) =
default;
422 _Optional_payload(_Optional_payload&&) =
default;
423 _Optional_payload& operator=(
const _Optional_payload&) =
default;
428 operator=(_Optional_payload&& __other)
429 noexcept(__and_v<is_nothrow_move_constructible<_Tp>,
430 is_nothrow_move_assignable<_Tp>>)
432 this->_M_move_assign(
std::move(__other));
438 template <
typename _Tp>
439 struct _Optional_payload<_Tp, true, false, false>
440 : _Optional_payload_base<_Tp>
442 using _Optional_payload_base<_Tp>::_Optional_payload_base;
444 _Optional_payload() =
default;
445 ~_Optional_payload() =
default;
446 _Optional_payload(
const _Optional_payload&) =
default;
447 _Optional_payload(_Optional_payload&&) =
default;
452 operator=(
const _Optional_payload& __other)
454 this->_M_copy_assign(__other);
461 operator=(_Optional_payload&& __other)
462 noexcept(__and_v<is_nothrow_move_constructible<_Tp>,
463 is_nothrow_move_assignable<_Tp>>)
465 this->_M_move_assign(
std::move(__other));
471 template <
typename _Tp,
bool _Copy,
bool _Move>
472 struct _Optional_payload<_Tp, false, _Copy, _Move>
473 : _Optional_payload<_Tp, true, false, false>
476 using _Optional_payload<_Tp,
true,
false,
false>::_Optional_payload;
477 _Optional_payload() =
default;
478 _Optional_payload(
const _Optional_payload&) =
default;
479 _Optional_payload(_Optional_payload&&) =
default;
480 _Optional_payload& operator=(
const _Optional_payload&) =
default;
481 _Optional_payload& operator=(_Optional_payload&&) =
default;
484 _GLIBCXX20_CONSTEXPR ~_Optional_payload() { this->_M_reset(); }
505 template<
typename _Tp,
506 bool = is_trivially_copy_constructible_v<_Tp>,
507 bool = is_trivially_move_constructible_v<_Tp>>
508 struct _Optional_base
511 constexpr _Optional_base() =
default;
514 template<
typename... _Args,
515 enable_if_t<is_constructible_v<_Tp, _Args...>,
bool> =
false>
517 _Optional_base(in_place_t, _Args&&... __args)
518 : _M_payload(in_place, std::
forward<_Args>(__args)...)
521 template<
typename _Up,
typename... _Args,
523 initializer_list<_Up>&,
524 _Args...>,
bool> =
false>
526 _Optional_base(in_place_t,
527 initializer_list<_Up> __il,
529 : _M_payload(in_place, __il, std::
forward<_Args>(__args)...)
534 _Optional_base(
const _Optional_base& __other)
535 noexcept(is_nothrow_copy_constructible_v<_Tp>)
536 : _M_payload(__other._M_payload._M_engaged, __other._M_payload)
540 _Optional_base(_Optional_base&& __other)
541 noexcept(is_nothrow_move_constructible_v<_Tp>)
542 : _M_payload(__other._M_payload._M_engaged,
543 std::move(__other._M_payload))
546#if __cpp_concepts >= 202002L
549 constexpr _Optional_base(
const _Optional_base&)
550 requires is_trivially_copy_constructible_v<_Tp> =
default;
552 constexpr _Optional_base(_Optional_base&&)
553 requires is_trivially_move_constructible_v<_Tp> = default;
557 _Optional_base& operator=(
const _Optional_base&) =
default;
558 _Optional_base& operator=(_Optional_base&&) =
default;
560 _Optional_payload<_Tp> _M_payload;
564 using _Stored_type = remove_const_t<_Tp>;
568 template<
typename... _Args>
570 _M_construct(_Args&&... __args)
571 noexcept(is_nothrow_constructible_v<_Stored_type, _Args...>)
577 _M_destruct() noexcept
578 { _M_payload._M_destroy(); }
583 { _M_payload._M_reset(); }
585 constexpr bool _M_is_engaged() const noexcept
586 {
return _M_payload._M_engaged; }
591 {
return _M_payload._M_get(); }
594 _M_get() const noexcept
595 {
return _M_payload._M_get(); }
598#if __cpp_concepts < 202002L
609 template<
typename _Tp,
typename _Dp>
610 class _Optional_base_impl
613 using _Stored_type = remove_const_t<_Tp>;
617 template<
typename... _Args>
619 _M_construct(_Args&&... __args)
620 noexcept(is_nothrow_constructible_v<_Stored_type, _Args...>)
622 static_cast<_Dp*
>(
this)->_M_payload._M_construct(
627 _M_destruct() noexcept
628 {
static_cast<_Dp*
>(
this)->_M_payload._M_destroy(); }
633 {
static_cast<_Dp*
>(
this)->_M_payload._M_reset(); }
635 constexpr bool _M_is_engaged() const noexcept
636 {
return static_cast<const _Dp*
>(
this)->_M_payload._M_engaged; }
641 {
return static_cast<_Dp*
>(
this)->_M_payload._M_get(); }
644 _M_get() const noexcept
645 {
return static_cast<const _Dp*
>(
this)->_M_payload._M_get(); }
648 template<
typename _Tp>
649 struct _Optional_base<_Tp, false, true>
650 : _Optional_base_impl<_Tp, _Optional_base<_Tp>>
653 constexpr _Optional_base() =
default;
656 template<
typename... _Args,
657 enable_if_t<is_constructible_v<_Tp, _Args...>,
bool> =
false>
659 _Optional_base(in_place_t, _Args&&... __args)
660 : _M_payload(in_place, std::
forward<_Args>(__args)...)
663 template<
typename _Up,
typename... _Args,
665 initializer_list<_Up>&,
666 _Args...>,
bool> =
false>
668 _Optional_base(in_place_t,
669 initializer_list<_Up> __il,
671 : _M_payload(in_place, __il, std::
forward<_Args>(__args)...)
675 constexpr _Optional_base(
const _Optional_base& __other)
676 : _M_payload(__other._M_payload._M_engaged, __other._M_payload)
679 constexpr _Optional_base(_Optional_base&& __other) =
default;
682 _Optional_base& operator=(
const _Optional_base&) =
default;
683 _Optional_base& operator=(_Optional_base&&) =
default;
685 _Optional_payload<_Tp> _M_payload;
688 template<
typename _Tp>
689 struct _Optional_base<_Tp, true, false>
690 : _Optional_base_impl<_Tp, _Optional_base<_Tp>>
693 constexpr _Optional_base() =
default;
696 template<
typename... _Args,
697 enable_if_t<is_constructible_v<_Tp, _Args...>,
bool> =
false>
699 _Optional_base(in_place_t, _Args&&... __args)
700 : _M_payload(in_place, std::
forward<_Args>(__args)...)
703 template<
typename _Up,
typename... _Args,
706 _Args...>,
bool> =
false>
708 _Optional_base(in_place_t,
711 : _M_payload(in_place, __il, std::
forward<_Args>(__args)...)
715 constexpr _Optional_base(
const _Optional_base& __other) =
default;
718 _Optional_base(_Optional_base&& __other)
719 noexcept(is_nothrow_move_constructible_v<_Tp>)
720 : _M_payload(__other._M_payload._M_engaged,
721 std::
move(__other._M_payload))
725 _Optional_base& operator=(
const _Optional_base&) =
default;
726 _Optional_base& operator=(_Optional_base&&) =
default;
728 _Optional_payload<_Tp> _M_payload;
731 template<
typename _Tp>
732 struct _Optional_base<_Tp, true, true>
733 : _Optional_base_impl<_Tp, _Optional_base<_Tp>>
736 constexpr _Optional_base() =
default;
739 template<
typename... _Args,
740 enable_if_t<is_constructible_v<_Tp, _Args...>,
bool> =
false>
742 _Optional_base(in_place_t, _Args&&... __args)
743 : _M_payload(in_place, std::
forward<_Args>(__args)...)
746 template<
typename _Up,
typename... _Args,
749 _Args...>,
bool> =
false>
751 _Optional_base(in_place_t,
754 : _M_payload(in_place, __il, std::
forward<_Args>(__args)...)
758 constexpr _Optional_base(
const _Optional_base& __other) =
default;
759 constexpr _Optional_base(_Optional_base&& __other) =
default;
762 _Optional_base& operator=(
const _Optional_base&) =
default;
763 _Optional_base& operator=(_Optional_base&&) =
default;
765 _Optional_payload<_Tp> _M_payload;
769 template<
typename _Tp>
770 inline constexpr bool __is_optional_v =
false;
771 template<
typename _Tp>
772 inline constexpr bool __is_optional_v<optional<_Tp>> =
true;
774 template<
typename _Tp,
typename _Wp>
775 using __converts_from_any_cvref = __or_<
782 template<
typename _Tp,
typename _Up>
783 using __converts_from_optional
784 = __converts_from_any_cvref<_Tp, optional<_Up>>;
786 template<
typename _Tp,
typename _Up>
787 using __assigns_from_optional =
788 __or_<is_assignable<_Tp&, const optional<_Up>&>,
793#if __cpp_concepts && __cpp_conditional_explicit && __glibcxx_remove_cvref
794# define _GLIBCXX_USE_CONSTRAINTS_FOR_OPTIONAL 1
797 template<
typename _Tp>
798 inline constexpr bool __is_valid_contained_type_for_optional =
800#if __cpp_lib_optional >= 202506L
801 is_lvalue_reference_v<_Tp> ||
803 (is_object_v<_Tp> && is_destructible_v<_Tp> && !is_array_v<_Tp>)
811 template<
typename _Tp>
813 :
private _Optional_base<_Tp>,
814 private _Enable_copy_move<
816 is_copy_constructible_v<_Tp>,
818 __and_v<is_copy_constructible<_Tp>, is_copy_assignable<_Tp>>,
820 is_move_constructible_v<_Tp>,
822 __and_v<is_move_constructible<_Tp>, is_move_assignable<_Tp>>,
826 static_assert(__is_valid_contained_type_for_optional<_Tp>);
829 using _Base = _Optional_base<_Tp>;
837#ifdef _GLIBCXX_USE_CONSTRAINTS_FOR_OPTIONAL
838 template<
typename _From,
typename = remove_cv_t<_Tp>>
839 static constexpr bool __not_constructing_bool_from_optional
844 template<
typename _From>
845 static constexpr bool
846 __not_constructing_bool_from_optional<_From, bool>
847 = !__is_optional_v<remove_cvref_t<_From>>;
853 template<
typename _From,
typename = remove_cv_t<_Tp>>
854 static constexpr bool __construct_from_contained_value
855 = !__converts_from_optional<_Tp, _From>::value;
859 template<
typename _From>
860 static constexpr bool __construct_from_contained_value<_From, bool>
863 template<
typename _From,
typename = remove_cv_t<_Tp>>
864 struct __not_constructing_bool_from_optional
868 template<
typename _From>
869 struct __not_constructing_bool_from_optional<_From, bool>
870 : bool_constant<!__is_optional_v<__remove_cvref_t<_From>>>
873 template<
typename _From,
typename = remove_cv_t<_Tp>>
874 struct __construct_from_contained_value
875 : __not_<__converts_from_optional<_Tp, _From>>
878 template<
typename _From>
879 struct __construct_from_contained_value<_From, bool>
883 template<
typename _Up>
884 using __not_self = __not_<is_same<optional, __remove_cvref_t<_Up>>>;
885 template<
typename _Up>
886 using __not_tag = __not_<is_same<in_place_t, __remove_cvref_t<_Up>>>;
887 template<
typename... _Cond>
888 using _Requires =
enable_if_t<__and_v<_Cond...>,
bool>;
892 using value_type = _Tp;
893#ifdef __cpp_lib_optional_range_support
894 using iterator = __gnu_cxx::__normal_iterator<_Tp*, optional>;
895 using const_iterator = __gnu_cxx::__normal_iterator<const _Tp*, optional>;
898 constexpr optional() noexcept { }
900 constexpr optional(nullopt_t)
noexcept { }
903#ifdef _GLIBCXX_USE_CONSTRAINTS_FOR_OPTIONAL
904 template<
typename _Up = remove_cv_t<_Tp>>
905 requires (!is_same_v<optional, remove_cvref_t<_Up>>)
906 && (!is_same_v<in_place_t, remove_cvref_t<_Up>>)
907 && is_constructible_v<_Tp, _Up>
908 && __not_constructing_bool_from_optional<_Up>
909 constexpr explicit(!is_convertible_v<_Up, _Tp>)
911 noexcept(is_nothrow_constructible_v<_Tp, _Up>)
912 : _Base(std::in_place, std::
forward<_Up>(__t)) { }
914 template<
typename _Up>
915 requires (!is_same_v<_Tp, _Up>)
916 && is_constructible_v<_Tp, const _Up&>
917 && __construct_from_contained_value<_Up>
918 constexpr explicit(!is_convertible_v<const _Up&, _Tp>)
919 optional(
const optional<_Up>& __t)
920 noexcept(is_nothrow_constructible_v<_Tp, const _Up&>)
923 emplace(__t._M_fwd());
926 template<
typename _Up>
927 requires (!is_same_v<_Tp, _Up>)
928 && is_constructible_v<_Tp, _Up>
929 && __construct_from_contained_value<_Up>
930 constexpr explicit(!is_convertible_v<_Up, _Tp>)
931 optional(optional<_Up>&& __t)
932 noexcept(is_nothrow_constructible_v<_Tp, _Up>)
938 template<
typename... _Args>
939 requires is_constructible_v<_Tp, _Args...>
941 optional(in_place_t, _Args&&... __args)
942 noexcept(is_nothrow_constructible_v<_Tp, _Args...>)
943 : _Base(std::in_place, std::
forward<_Args>(__args)...)
946 template<
typename _Up,
typename... _Args>
947 requires is_constructible_v<_Tp, initializer_list<_Up>&, _Args...>
949 optional(in_place_t, initializer_list<_Up> __il, _Args&&... __args)
950 noexcept(is_nothrow_constructible_v<_Tp, initializer_list<_Up>&,
952 : _Base(std::in_place, __il, std::
forward<_Args>(__args)...)
955 template<
typename _Up = remove_cv_t<_Tp>,
956 _Requires<__not_self<_Up>, __not_tag<_Up>,
957 is_constructible<_Tp, _Up>,
958 is_convertible<_Up, _Tp>,
959 __not_constructing_
bool_from_optional<_Up>> = true>
962 noexcept(is_nothrow_constructible_v<_Tp, _Up>)
963 : _Base(std::in_place, std::
forward<_Up>(__t)) { }
965 template<
typename _Up = remove_cv_t<_Tp>,
966 _Requires<__not_self<_Up>, __not_tag<_Up>,
967 is_constructible<_Tp, _Up>,
968 __not_<is_convertible<_Up, _Tp>>,
969 __not_constructing_
bool_from_optional<_Up>> = false>
972 noexcept(is_nothrow_constructible_v<_Tp, _Up>)
973 : _Base(std::in_place, std::
forward<_Up>(__t)) { }
975 template<
typename _Up,
976 _Requires<__not_<is_same<_Tp, _Up>>,
977 is_constructible<_Tp, const _Up&>,
978 is_convertible<const _Up&, _Tp>,
979 __construct_from_contained_value<_Up>> =
true>
981 optional(
const optional<_Up>& __t)
982 noexcept(is_nothrow_constructible_v<_Tp, const _Up&>)
985 emplace(__t._M_fwd());
988 template<
typename _Up,
989 _Requires<__not_<is_same<_Tp, _Up>>,
990 is_constructible<_Tp, const _Up&>,
991 __not_<is_convertible<const _Up&, _Tp>>,
992 __construct_from_contained_value<_Up>> =
false>
994 optional(
const optional<_Up>& __t)
995 noexcept(is_nothrow_constructible_v<_Tp, const _Up&>)
998 emplace(__t._M_fwd());
1001 template<
typename _Up,
1002 _Requires<__not_<is_same<_Tp, _Up>>,
1003 is_constructible<_Tp, _Up>,
1004 is_convertible<_Up, _Tp>,
1005 __construct_from_contained_value<_Up>> =
true>
1007 optional(optional<_Up>&& __t)
1008 noexcept(is_nothrow_constructible_v<_Tp, _Up>)
1014 template<
typename _Up,
1015 _Requires<__not_<is_same<_Tp, _Up>>,
1016 is_constructible<_Tp, _Up>,
1017 __not_<is_convertible<_Up, _Tp>>,
1018 __construct_from_contained_value<_Up>> =
false>
1020 optional(optional<_Up>&& __t)
1021 noexcept(is_nothrow_constructible_v<_Tp, _Up>)
1027 template<
typename... _Args,
1028 _Requires<is_constructible<_Tp, _Args...>> =
false>
1030 optional(in_place_t, _Args&&... __args)
1031 noexcept(is_nothrow_constructible_v<_Tp, _Args...>)
1032 : _Base(std::in_place, std::
forward<_Args>(__args)...) { }
1034 template<
typename _Up,
typename... _Args,
1035 _Requires<is_constructible<_Tp,
1036 initializer_list<_Up>&,
1039 optional(in_place_t, initializer_list<_Up> __il, _Args&&... __args)
1040 noexcept(is_nothrow_constructible_v<_Tp, initializer_list<_Up>&,
1042 : _Base(std::in_place, __il, std::
forward<_Args>(__args)...) { }
1046 _GLIBCXX20_CONSTEXPR optional&
1047 operator=(nullopt_t)
noexcept
1053 template<
typename _Up = remove_cv_t<_Tp>>
1054#ifdef _GLIBCXX_USE_CONSTRAINTS_FOR_OPTIONAL
1055 requires (!is_same_v<optional, remove_cvref_t<_Up>>)
1056 && (!(is_scalar_v<_Tp> && is_same_v<_Tp,
decay_t<_Up>>))
1057 && is_constructible_v<_Tp, _Up>
1058 && is_assignable_v<_Tp&, _Up>
1062 __not_<__and_<is_scalar<_Tp>,
1063 is_same<_Tp, decay_t<_Up>>>>,
1064 is_constructible<_Tp, _Up>,
1065 is_assignable<_Tp&, _Up>>,
1068 operator=(_Up&& __u)
1069 noexcept(__and_v<is_nothrow_constructible<_Tp, _Up>,
1070 is_nothrow_assignable<_Tp&, _Up>>)
1072 if (this->_M_is_engaged())
1080 template<
typename _Up>
1081#ifdef _GLIBCXX_USE_CONSTRAINTS_FOR_OPTIONAL
1082 requires (!is_same_v<_Tp, _Up>)
1083 && is_constructible_v<_Tp, const _Up&>
1084 && is_assignable_v<_Tp&, const _Up&>
1085 && (!__converts_from_optional<_Tp, _Up>::value)
1086 && (!__assigns_from_optional<_Tp, _Up>::value)
1090 is_constructible<_Tp, const _Up&>,
1091 is_assignable<_Tp&, const _Up&>,
1092 __not_<__converts_from_optional<_Tp, _Up>>,
1093 __not_<__assigns_from_optional<_Tp, _Up>>>,
1096 operator=(
const optional<_Up>& __u)
1097 noexcept(__and_v<is_nothrow_constructible<_Tp, const _Up&>,
1098 is_nothrow_assignable<_Tp&, const _Up&>>)
1102 if (this->_M_is_engaged())
1103 this->_M_get() = __u._M_fwd();
1105 this->_M_construct(__u._M_fwd());
1114 template<
typename _Up>
1115#ifdef _GLIBCXX_USE_CONSTRAINTS_FOR_OPTIONAL
1116 requires (!is_same_v<_Tp, _Up>)
1117 && is_constructible_v<_Tp, _Up>
1118 && is_assignable_v<_Tp&, _Up>
1119 && (!__converts_from_optional<_Tp, _Up>::value)
1120 && (!__assigns_from_optional<_Tp, _Up>::value)
1124 is_constructible<_Tp, _Up>,
1125 is_assignable<_Tp&, _Up>,
1126 __not_<__converts_from_optional<_Tp, _Up>>,
1127 __not_<__assigns_from_optional<_Tp, _Up>>>,
1130 operator=(optional<_Up>&& __u)
1131 noexcept(__and_v<is_nothrow_constructible<_Tp, _Up>,
1132 is_nothrow_assignable<_Tp&, _Up>>)
1136 if (this->_M_is_engaged())
1137 this->_M_get() =
std::move(__u)._M_fwd();
1139 this->_M_construct(
std::move(__u)._M_fwd());
1151 template<
typename... _Args>
1152 _GLIBCXX20_CONSTEXPR
1153 enable_if_t<is_constructible_v<_Tp, _Args...>, _Tp&>
1154 emplace(_Args&&... __args)
1155 noexcept(is_nothrow_constructible_v<_Tp, _Args...>)
1159 return this->_M_get();
1162 template<
typename _Up,
typename... _Args>
1163 _GLIBCXX20_CONSTEXPR
1166 emplace(initializer_list<_Up> __il, _Args&&... __args)
1167 noexcept(is_nothrow_constructible_v<_Tp, initializer_list<_Up>&,
1172 return this->_M_get();
1178 _GLIBCXX20_CONSTEXPR
void
1179 swap(optional& __other)
1180 noexcept(is_nothrow_move_constructible_v<_Tp>
1181 && is_nothrow_swappable_v<_Tp>)
1185 if (this->_M_is_engaged() && __other._M_is_engaged())
1186 swap(this->_M_get(), __other._M_get());
1187 else if (this->_M_is_engaged())
1189 __other._M_construct(
std::move(this->_M_get()));
1190 this->_M_destruct();
1192 else if (__other._M_is_engaged())
1194 this->_M_construct(
std::move(__other._M_get()));
1195 __other._M_destruct();
1199#ifdef __cpp_lib_optional_range_support
1201 constexpr iterator
begin() noexcept
1208 constexpr const_iterator
begin() const noexcept
1210 return const_iterator(
1215 constexpr iterator
end() noexcept
1217 return begin() + has_value();
1220 constexpr const_iterator
end() const noexcept
1222 return begin() + has_value();
1227 constexpr const _Tp*
1228 operator->() const noexcept
1230 __glibcxx_assert(this->_M_is_engaged());
1235 operator->() noexcept
1237 __glibcxx_assert(this->_M_is_engaged());
1241 constexpr const _Tp&
1244 __glibcxx_assert(this->_M_is_engaged());
1245 return this->_M_get();
1251 __glibcxx_assert(this->_M_is_engaged());
1252 return this->_M_get();
1258 __glibcxx_assert(this->_M_is_engaged());
1262 constexpr const _Tp&&
1265 __glibcxx_assert(this->_M_is_engaged());
1269 constexpr explicit operator bool() const noexcept
1270 {
return this->_M_is_engaged(); }
1272 constexpr bool has_value() const noexcept
1273 {
return this->_M_is_engaged(); }
1275 constexpr const _Tp&
1278 if (this->_M_is_engaged())
1279 return this->_M_get();
1280 __throw_bad_optional_access();
1286 if (this->_M_is_engaged())
1287 return this->_M_get();
1288 __throw_bad_optional_access();
1294 if (this->_M_is_engaged())
1296 __throw_bad_optional_access();
1299 constexpr const _Tp&&
1302 if (this->_M_is_engaged())
1304 __throw_bad_optional_access();
1309 template<
typename _Up = remove_cv_t<_Tp>>
1310 constexpr remove_cv_t<_Tp>
1311 value_or(_Up&& __u)
const&
1313 using _Xp = remove_cv_t<_Tp>;
1314 static_assert(is_convertible_v<const _Tp&, _Xp>);
1315 static_assert(is_convertible_v<_Up, _Xp>);
1317 if (this->_M_is_engaged())
1318 return this->_M_get();
1322 template<
typename _Up = remove_cv_t<_Tp>>
1323 constexpr remove_cv_t<_Tp>
1324 value_or(_Up&& __u) &&
1326 using _Xp = remove_cv_t<_Tp>;
1327 static_assert(is_convertible_v<_Tp, _Xp>);
1328 static_assert(is_convertible_v<_Up, _Xp>);
1330 if (this->_M_is_engaged())
1335#if __cpp_lib_optional >= 202110L
1338 template<
typename _Fn>
1340 and_then(_Fn&& __f) &
1342 using _Up = remove_cvref_t<invoke_result_t<_Fn, _Tp&>>;
1343 static_assert(__is_optional_v<_Up>,
1344 "the function passed to std::optional<T>::and_then "
1345 "must return a std::optional");
1352 template<
typename _Fn>
1354 and_then(_Fn&& __f)
const &
1356 using _Up = remove_cvref_t<invoke_result_t<_Fn, const _Tp&>>;
1357 static_assert(__is_optional_v<_Up>,
1358 "the function passed to std::optional<T>::and_then "
1359 "must return a std::optional");
1366 template<
typename _Fn>
1368 and_then(_Fn&& __f) &&
1370 using _Up = remove_cvref_t<invoke_result_t<_Fn, _Tp>>;
1371 static_assert(__is_optional_v<_Up>,
1372 "the function passed to std::optional<T>::and_then "
1373 "must return a std::optional");
1380 template<
typename _Fn>
1382 and_then(_Fn&& __f)
const &&
1384 using _Up = remove_cvref_t<invoke_result_t<_Fn, const _Tp>>;
1385 static_assert(__is_optional_v<_Up>,
1386 "the function passed to std::optional<T>::and_then "
1387 "must return a std::optional");
1394 template<
typename _Fn>
1396 transform(_Fn&& __f) &
1398 using _Up = remove_cv_t<invoke_result_t<_Fn, _Tp&>>;
1400 return optional<_Up>(_Optional_func<_Fn>{__f}, _M_get());
1402 return optional<_Up>();
1405 template<
typename _Fn>
1407 transform(_Fn&& __f)
const &
1409 using _Up = remove_cv_t<invoke_result_t<_Fn, const _Tp&>>;
1411 return optional<_Up>(_Optional_func<_Fn>{__f}, _M_get());
1413 return optional<_Up>();
1416 template<
typename _Fn>
1418 transform(_Fn&& __f) &&
1420 using _Up = remove_cv_t<invoke_result_t<_Fn, _Tp>>;
1422 return optional<_Up>(_Optional_func<_Fn>{__f},
std::move(_M_get()));
1424 return optional<_Up>();
1427 template<
typename _Fn>
1429 transform(_Fn&& __f)
const &&
1431 using _Up = remove_cv_t<invoke_result_t<_Fn, const _Tp>>;
1433 return optional<_Up>(_Optional_func<_Fn>{__f},
std::move(_M_get()));
1435 return optional<_Up>();
1438 template<
typename _Fn>
requires invocable<_Fn> && copy_constructible<_Tp>
1440 or_else(_Fn&& __f)
const&
1442 using _Up = invoke_result_t<_Fn>;
1443 static_assert(is_same_v<remove_cvref_t<_Up>, optional>,
1444 "the function passed to std::optional<T>::or_else "
1445 "must return a std::optional<T>");
1453 template<
typename _Fn>
requires invocable<_Fn> && move_constructible<_Tp>
1455 or_else(_Fn&& __f) &&
1457 using _Up = invoke_result_t<_Fn>;
1458 static_assert(is_same_v<remove_cvref_t<_Up>, optional>,
1459 "the function passed to std::optional<T>::or_else "
1460 "must return a std::optional<T>");
1469 _GLIBCXX20_CONSTEXPR
void reset() noexcept { this->_M_reset(); }
1472 using _Base::_M_get;
1474 [[__gnu__::__always_inline__]]
1477 {
return _M_get(); }
1479 [[__gnu__::__always_inline__]]
1481 _M_fwd() &&
noexcept
1484 [[__gnu__::__always_inline__]]
1485 constexpr const _Tp&
1486 _M_fwd() const& noexcept
1487 {
return _M_get(); }
1489 [[__gnu__::__always_inline__]]
1490 constexpr const _Tp&&
1491 _M_fwd() const&& noexcept
1494 template<
typename _Up>
friend class optional;
1496#if __cpp_lib_optional >= 202110L
1497 template<
typename _Fn,
typename _Value>
1499 optional(_Optional_func<_Fn> __f, _Value&& __v)
1506#if __cpp_lib_optional >= 202506L
1507 template<
typename _Tp>
1508 class optional<_Tp&>;
1510 template<
typename _Tp>
1511 constexpr bool __is_optional_ref_v =
false;
1513 template<
typename _Tp>
1514 constexpr bool __is_optional_ref_v<optional<_Tp&>> =
true;
1516 template<
typename _Tp>
1517 struct __optional_ref_base
1520#ifdef __cpp_lib_optional_range_support
1521 template<
typename _Tp>
1522 struct __optional_ref_base<_Tp[]>
1525 template<
typename _Tp>
1526 requires is_object_v<_Tp>
1527 struct __optional_ref_base<_Tp>
1529 using iterator = __gnu_cxx::__normal_iterator<_Tp*, optional<_Tp&>>;
1533 template<
typename _Tp>
1534 class optional<_Tp&> :
public __optional_ref_base<_Tp>
1536 static_assert(__is_valid_contained_type_for_optional<_Tp&>);
1542 constexpr optional() noexcept = default;
1543 constexpr optional(nullopt_t) noexcept : optional() {}
1544 constexpr optional(
const optional&)
noexcept =
default;
1546 template<
typename _Arg>
1547 requires is_constructible_v<_Tp&, _Arg>
1548 && (!reference_constructs_from_temporary_v<_Tp&, _Arg>)
1550 optional(in_place_t, _Arg&& __arg)
1555 template<
typename _Up>
1556 requires (!is_same_v<remove_cvref_t<_Up>, optional>)
1557 && (!is_same_v<remove_cvref_t<_Up>, in_place_t>)
1558 && is_constructible_v<_Tp&, _Up>
1559 && (!reference_constructs_from_temporary_v<_Tp&, _Up>)
1560 explicit(!is_convertible_v<_Up, _Tp&>)
1563 noexcept(is_nothrow_constructible_v<_Tp&, _Up>)
1568 template<
typename _Up>
1569 requires (!is_same_v<remove_cvref_t<_Up>, optional>)
1570 && (!is_same_v<remove_cvref_t<_Up>, in_place_t>)
1571 && is_constructible_v<_Tp&, _Up>
1572 && reference_constructs_from_temporary_v<_Tp&, _Up>
1573 explicit(!is_convertible_v<_Up, _Tp&>)
1575 optional(_Up&& __u) =
delete;
1578 template<
typename _Up>
1579 requires (!is_same_v<remove_cv_t<_Tp>, optional<_Up>>)
1580 && (!is_same_v<_Tp&, _Up>)
1581 && is_constructible_v<_Tp&, _Up&>
1582 && (!reference_constructs_from_temporary_v<_Tp&, _Up&>)
1583 explicit(!is_convertible_v<_Up&, _Tp&>)
1585 optional(optional<_Up>& __rhs)
1586 noexcept(is_nothrow_constructible_v<_Tp&, _Up&>)
1589 __convert_ref_init_val(__rhs._M_fwd());
1592 template<
typename _Up>
1593 requires (!is_same_v<remove_cv_t<_Tp>, optional<_Up>>)
1594 && (!is_same_v<_Tp&, _Up>)
1595 && is_constructible_v<_Tp&, _Up&>
1596 && reference_constructs_from_temporary_v<_Tp&, _Up&>
1597 explicit(!is_convertible_v<_Up&, _Tp&>)
1599 optional(optional<_Up>& __rhs) =
delete;
1602 template<
typename _Up>
1603 requires (!is_same_v<remove_cv_t<_Tp>, optional<_Up>>)
1604 && (!is_same_v<_Tp&, _Up>)
1605 && is_constructible_v<_Tp&, const _Up&>
1606 && (!reference_constructs_from_temporary_v<_Tp&, const _Up&>)
1607 explicit(!is_convertible_v<const _Up&, _Tp&>)
1609 optional(
const optional<_Up>& __rhs)
1610 noexcept(is_nothrow_constructible_v<_Tp&, _Up&>)
1613 __convert_ref_init_val(__rhs._M_fwd());
1616 template<
typename _Up>
1617 requires (!is_same_v<remove_cv_t<_Tp>, optional<_Up>>)
1618 && (!is_same_v<_Tp&, _Up>)
1619 && is_constructible_v<_Tp&, const _Up&>
1620 && reference_constructs_from_temporary_v<_Tp&, const _Up&>
1621 explicit(!is_convertible_v<const _Up&, _Tp&>)
1623 optional(
const optional<_Up>& __rhs) =
delete;
1626 template<
typename _Up>
1627 requires (!is_same_v<remove_cv_t<_Tp>, optional<_Up>>)
1628 && (!is_same_v<_Tp&, _Up>)
1629 && is_constructible_v<_Tp&, _Up>
1630 && (!reference_constructs_from_temporary_v<_Tp&, _Up>)
1631 explicit(!is_convertible_v<_Up, _Tp&>)
1633 optional(optional<_Up>&& __rhs)
1634 noexcept(is_nothrow_constructible_v<_Tp&, _Up>)
1637 __convert_ref_init_val(
std::move(__rhs)._M_fwd());
1640 template<
typename _Up>
1641 requires (!is_same_v<remove_cv_t<_Tp>, optional<_Up>>)
1642 && (!is_same_v<_Tp&, _Up>)
1643 && is_constructible_v<_Tp&, _Up>
1644 && reference_constructs_from_temporary_v<_Tp&, _Up>
1645 explicit(!is_convertible_v<_Up, _Tp&>)
1647 optional(optional<_Up>&& __rhs) =
delete;
1650 template<
typename _Up>
1651 requires (!is_same_v<remove_cv_t<_Tp>, optional<_Up>>)
1652 && (!is_same_v<_Tp&, _Up>)
1653 && is_constructible_v<_Tp&, const _Up>
1654 && (!reference_constructs_from_temporary_v<_Tp&, _Up>)
1655 explicit(!is_convertible_v<const _Up, _Tp&>)
1657 optional(
const optional<_Up>&& __rhs)
1658 noexcept(is_nothrow_constructible_v<_Tp&, const _Up>)
1661 __convert_ref_init_val(
std::move(__rhs)._M_fwd());
1664 template<
typename _Up>
1665 requires (!is_same_v<remove_cv_t<_Tp>, optional<_Up>>)
1666 && (!is_same_v<_Tp&, _Up>)
1667 && is_constructible_v<_Tp&, const _Up>
1668 && reference_constructs_from_temporary_v<_Tp&, const _Up>
1669 explicit(!is_convertible_v<const _Up, _Tp&>)
1671 optional(
const optional<_Up>&& __rhs) =
delete;
1673 constexpr ~optional() =
default;
1676 constexpr optional& operator=(nullopt_t)
noexcept
1682 constexpr optional& operator=(
const optional&)
noexcept =
default;
1684 template<
typename _Up>
1685 requires is_constructible_v<_Tp&, _Up>
1686 && (!reference_constructs_from_temporary_v<_Tp&, _Up>)
1689 noexcept(is_nothrow_constructible_v<_Tp&, _Up>)
1698 constexpr void swap(optional& __rhs)
noexcept
1699 { std::swap(_M_val, __rhs._M_val); }
1701#ifdef __cpp_lib_optional_range_support
1703 constexpr auto begin() const noexcept
1704 requires is_object_v<_Tp> && (!is_unbounded_array_v<_Tp>)
1705 {
return __gnu_cxx::__normal_iterator<_Tp*, optional>(_M_val); }
1707 constexpr auto end() const noexcept
1708 requires is_object_v<_Tp> && (!is_unbounded_array_v<_Tp>)
1709 {
return begin() + has_value(); }
1713 constexpr _Tp* operator->() const noexcept
1715 __glibcxx_assert(_M_val);
1719 constexpr _Tp&
operator*() const noexcept
1721 __glibcxx_assert(_M_val);
1725 constexpr explicit operator bool() const noexcept
1730 constexpr bool has_value() const noexcept
1735 constexpr _Tp& value()
const
1739 __throw_bad_optional_access();
1744 template<
typename _Up = remove_cv_t<_Tp>>
1745 requires is_object_v<_Tp> && (!is_array_v<_Tp>)
1747 value_or(_Up&& __u)
const
1749 using _Xp = remove_cv_t<_Tp>;
1750 static_assert(is_convertible_v<_Tp&, _Xp>);
1751 static_assert(is_convertible_v<_Up, _Xp>);
1758 template<
typename _Fn>
1760 and_then(_Fn&& __f)
const
1762 using _Up = remove_cvref_t<invoke_result_t<_Fn, _Tp&>>;
1763 static_assert(__is_optional_v<_Up>,
1764 "the function passed to std::optional<T&>::and_then "
1765 "must return a std::optional");
1772 template<
typename _Fn>
1774 optional<remove_cv_t<invoke_result_t<_Fn, _Tp&>>>
1775 transform(_Fn&& __f)
const
1777 using _Up = remove_cv_t<invoke_result_t<_Fn, _Tp&>>;
1779 return optional<_Up>(_Optional_func<_Fn>{__f}, *_M_val);
1781 return optional<_Up>();
1784 template<
typename _Fn>
1788 or_else(_Fn&& __f)
const
1790 static_assert(is_same_v<remove_cvref_t<invoke_result_t<_Fn>>, optional>,
1791 "the function passed to std::optional<T&>::or_else "
1792 "must return a std::optional<T&>");
1802 constexpr void reset() noexcept
1808 _Tp *_M_val =
nullptr;
1810 [[__gnu__::__always_inline__]]
1812 _M_fwd() const noexcept
1815 template<
typename _Up>
friend class optional;
1817 template<
typename _Up>
1820 __convert_ref_init_val(_Up&& __u)
1827 template<
typename _Fn,
typename _Value>
1829 optional(_Optional_func<_Fn> __f, _Value&& __v)
1837 template<
typename _Tp>
1838 using __optional_relop_t =
1841 template<
typename _Tp,
typename _Up>
1842 using __optional_eq_t = __optional_relop_t<
1846 template<
typename _Tp,
typename _Up>
1847 using __optional_ne_t = __optional_relop_t<
1851 template<
typename _Tp,
typename _Up>
1852 using __optional_lt_t = __optional_relop_t<
1856 template<
typename _Tp,
typename _Up>
1857 using __optional_gt_t = __optional_relop_t<
1861 template<
typename _Tp,
typename _Up>
1862 using __optional_le_t = __optional_relop_t<
1866 template<
typename _Tp,
typename _Up>
1867 using __optional_ge_t = __optional_relop_t<
1872 template<
typename _Tp,
typename _Up>
1874 operator==(
const optional<_Tp>& __lhs,
const optional<_Up>& __rhs)
1875 -> __optional_eq_t<_Tp, _Up>
1877 if (__lhs.has_value() != __rhs.has_value())
1879 if (!__lhs.has_value())
1881 return *__lhs == *__rhs;
1884 template<
typename _Tp,
typename _Up>
1886 operator!=(
const optional<_Tp>& __lhs,
const optional<_Up>& __rhs)
1887 -> __optional_ne_t<_Tp, _Up>
1889 if (__lhs.has_value() != __rhs.has_value())
1891 if (!__lhs.has_value())
1893 return *__lhs != *__rhs;
1896 template<
typename _Tp,
typename _Up>
1898 operator<(
const optional<_Tp>& __lhs,
const optional<_Up>& __rhs)
1899 -> __optional_lt_t<_Tp, _Up>
1901 if (!__rhs.has_value())
1903 if (!__lhs.has_value())
1905 return *__lhs < *__rhs;
1908 template<
typename _Tp,
typename _Up>
1910 operator>(
const optional<_Tp>& __lhs,
const optional<_Up>& __rhs)
1911 -> __optional_gt_t<_Tp, _Up>
1913 if (!__lhs.has_value())
1915 if (!__rhs.has_value())
1917 return *__lhs > *__rhs;
1920 template<
typename _Tp,
typename _Up>
1922 operator<=(
const optional<_Tp>& __lhs,
const optional<_Up>& __rhs)
1923 -> __optional_le_t<_Tp, _Up>
1925 if (!__lhs.has_value())
1927 if (!__rhs.has_value())
1929 return *__lhs <= *__rhs;
1932 template<
typename _Tp,
typename _Up>
1934 operator>=(
const optional<_Tp>& __lhs,
const optional<_Up>& __rhs)
1935 -> __optional_ge_t<_Tp, _Up>
1937 if (!__rhs.has_value())
1939 if (!__lhs.has_value())
1941 return *__lhs >= *__rhs;
1944#ifdef __cpp_lib_three_way_comparison
1945 template<
typename _Tp, three_way_comparable_with<_Tp> _Up>
1948 operator<=>(
const optional<_Tp>& __x,
const optional<_Up>& __y)
1950 return __x && __y ? *__x <=> *__y : bool(__x) <=> bool(__y);
1955 template<
typename _Tp>
1958 operator==(
const optional<_Tp>& __lhs, nullopt_t)
noexcept
1961#ifdef __cpp_lib_three_way_comparison
1962 template<
typename _Tp>
1964 constexpr strong_ordering
1965 operator<=>(
const optional<_Tp>& __x, nullopt_t)
noexcept
1966 {
return bool(__x) <=>
false; }
1968 template<
typename _Tp>
1970 operator==(nullopt_t,
const optional<_Tp>& __rhs)
noexcept
1973 template<
typename _Tp>
1975 operator!=(
const optional<_Tp>& __lhs, nullopt_t)
noexcept
1976 {
return static_cast<bool>(__lhs); }
1978 template<
typename _Tp>
1980 operator!=(nullopt_t,
const optional<_Tp>& __rhs)
noexcept
1981 {
return static_cast<bool>(__rhs); }
1983 template<
typename _Tp>
1985 operator<(
const optional<_Tp>& , nullopt_t)
noexcept
1988 template<
typename _Tp>
1990 operator<(nullopt_t,
const optional<_Tp>& __rhs)
noexcept
1991 {
return static_cast<bool>(__rhs); }
1993 template<
typename _Tp>
1995 operator>(
const optional<_Tp>& __lhs, nullopt_t)
noexcept
1996 {
return static_cast<bool>(__lhs); }
1998 template<
typename _Tp>
2000 operator>(nullopt_t,
const optional<_Tp>& )
noexcept
2003 template<
typename _Tp>
2005 operator<=(
const optional<_Tp>& __lhs, nullopt_t)
noexcept
2008 template<
typename _Tp>
2010 operator<=(nullopt_t,
const optional<_Tp>& )
noexcept
2013 template<
typename _Tp>
2015 operator>=(
const optional<_Tp>& , nullopt_t)
noexcept
2018 template<
typename _Tp>
2020 operator>=(nullopt_t,
const optional<_Tp>& __rhs)
noexcept
2024#if __cpp_lib_concepts
2027# define _REQUIRES_NOT_OPTIONAL(T) requires (!__is_optional_v<T>)
2029# define _REQUIRES_NOT_OPTIONAL(T)
2033 template<
typename _Tp,
typename _Up>
2034 _REQUIRES_NOT_OPTIONAL(_Up)
2036 operator== [[nodiscard]] (
const optional<_Tp>& __lhs,
const _Up& __rhs)
2037 -> __optional_eq_t<_Tp, _Up>
2039 if (__lhs.has_value())
2040 return *__lhs == __rhs;
2044 template<
typename _Tp,
typename _Up>
2045 _REQUIRES_NOT_OPTIONAL(_Tp)
2047 operator== [[nodiscard]] (
const _Tp& __lhs,
const optional<_Up>& __rhs)
2048 -> __optional_eq_t<_Tp, _Up>
2050 if (__rhs.has_value())
2051 return __lhs == *__rhs;
2055 template<
typename _Tp,
typename _Up>
2056 _REQUIRES_NOT_OPTIONAL(_Up)
2058 operator!= [[nodiscard]] (
const optional<_Tp>& __lhs,
const _Up& __rhs)
2059 -> __optional_ne_t<_Tp, _Up>
2061 if (__lhs.has_value())
2062 return *__lhs != __rhs;
2066 template<
typename _Tp,
typename _Up>
2067 _REQUIRES_NOT_OPTIONAL(_Tp)
2069 operator!= [[nodiscard]] (
const _Tp& __lhs,
const optional<_Up>& __rhs)
2070 -> __optional_ne_t<_Tp, _Up>
2072 if (__rhs.has_value())
2073 return __lhs != *__rhs;
2077 template<
typename _Tp,
typename _Up>
2078 _REQUIRES_NOT_OPTIONAL(_Up)
2080 operator< [[nodiscard]] (
const optional<_Tp>& __lhs,
const _Up& __rhs)
2081 -> __optional_lt_t<_Tp, _Up>
2083 if (__lhs.has_value())
2084 return *__lhs < __rhs;
2088 template<
typename _Tp,
typename _Up>
2089 _REQUIRES_NOT_OPTIONAL(_Tp)
2091 operator< [[nodiscard]] (
const _Tp& __lhs,
const optional<_Up>& __rhs)
2092 -> __optional_lt_t<_Tp, _Up>
2094 if (__rhs.has_value())
2095 return __lhs < *__rhs;
2099 template<
typename _Tp,
typename _Up>
2100 _REQUIRES_NOT_OPTIONAL(_Up)
2102 operator> [[nodiscard]] (
const optional<_Tp>& __lhs,
const _Up& __rhs)
2103 -> __optional_gt_t<_Tp, _Up>
2105 if (__lhs.has_value())
2106 return *__lhs > __rhs;
2110 template<
typename _Tp,
typename _Up>
2111 _REQUIRES_NOT_OPTIONAL(_Tp)
2113 operator> [[nodiscard]] (
const _Tp& __lhs,
const optional<_Up>& __rhs)
2114 -> __optional_gt_t<_Tp, _Up>
2116 if (__rhs.has_value())
2117 return __lhs > *__rhs;
2121 template<
typename _Tp,
typename _Up>
2122 _REQUIRES_NOT_OPTIONAL(_Up)
2124 operator<= [[nodiscard]] (
const optional<_Tp>& __lhs,
const _Up& __rhs)
2125 -> __optional_le_t<_Tp, _Up>
2127 if (__lhs.has_value())
2128 return *__lhs <= __rhs;
2132 template<
typename _Tp,
typename _Up>
2133 _REQUIRES_NOT_OPTIONAL(_Tp)
2135 operator<= [[nodiscard]] (
const _Tp& __lhs,
const optional<_Up>& __rhs)
2136 -> __optional_le_t<_Tp, _Up>
2138 if (__rhs.has_value())
2139 return __lhs <= *__rhs;
2143 template<
typename _Tp,
typename _Up>
2144 _REQUIRES_NOT_OPTIONAL(_Up)
2146 operator>= [[nodiscard]] (
const optional<_Tp>& __lhs,
const _Up& __rhs)
2147 -> __optional_ge_t<_Tp, _Up>
2149 if (__lhs.has_value())
2150 return *__lhs >= __rhs;
2154 template<
typename _Tp,
typename _Up>
2155 _REQUIRES_NOT_OPTIONAL(_Tp)
2157 operator>= [[nodiscard]] (
const _Tp& __lhs,
const optional<_Up>& __rhs)
2158 -> __optional_ge_t<_Tp, _Up>
2160 if (__rhs.has_value())
2161 return __lhs >= *__rhs;
2165#ifdef __cpp_lib_three_way_comparison
2169 template<
typename _Tp>
2170 concept __is_derived_from_optional =
requires (
const _Tp& __t) {
2171 []<
typename _Up>(
const optional<_Up>&){ }(__t);
2174 template<
typename _Tp,
typename _Up>
2175 requires (!__is_derived_from_optional<_Up>)
2177 && three_way_comparable_with<_Tp, _Up>
2179 operator<=> [[nodiscard]] (
const optional<_Tp>& __x,
const _Up& __v)
2180 {
return bool(__x) ? *__x <=> __v : strong_ordering::less; }
2187 template<
typename _Tp>
2188 _GLIBCXX20_CONSTEXPR
2190 swap(optional<_Tp>& __lhs, optional<_Tp>& __rhs)
2191 noexcept(
noexcept(__lhs.swap(__rhs)))
2192 { __lhs.swap(__rhs); }
2194#if __cpp_lib_optional >= 202506L
2197 template<
typename _Tp>
2199 swap(optional<_Tp&>& __lhs, optional<_Tp&>& __rhs)
noexcept
2200 { __lhs.swap(__rhs); }
2205 template<
typename _Tp>
2206 enable_if_t<!(is_move_constructible_v<_Tp> && is_swappable_v<_Tp>)>
2207 swap(optional<_Tp>&, optional<_Tp>&) =
delete;
2209#if __cpp_lib_optional >= 202506L
2210 template<
int = 0,
typename _Tp>
2212 template<
typename _Tp>
2216 optional<decay_t<_Tp>>>
2217 make_optional(_Tp&& __t)
2218 noexcept(is_nothrow_constructible_v<optional<decay_t<_Tp>>, _Tp>)
2221 template<
typename _Tp,
typename... _Args>
2225 make_optional(_Args&&... __args)
2226 noexcept(is_nothrow_constructible_v<_Tp, _Args...>)
2229 template<
typename _Tp,
typename _Up,
typename... _Args>
2234 noexcept(is_nothrow_constructible_v<_Tp, initializer_list<_Up>&, _Args...>)
2239 template<
typename _Tp,
typename _Up = remove_const_t<_Tp>>
2240 struct __optional_hash
2241#if ! _GLIBCXX_INLINE_VERSION
2242 :
public __hash_empty_base<_Up>
2245#if __cplusplus < 202002L
2246 using result_type [[__deprecated__]] = size_t;
2247 using argument_type [[__deprecated__]] = optional<_Tp>;
2251 operator()(
const optional<_Tp>& __t)
const
2252 noexcept(
noexcept(hash<_Up>{}(*__t)))
2256 constexpr size_t __magic_disengaged_hash =
static_cast<size_t>(-3333);
2257 return __t ? hash<_Up>{}(*__t) : __magic_disengaged_hash;
2261 template<
typename _Tp>
2262 struct hash<optional<_Tp>>
2264 :
public __conditional_t<__is_hash_enabled_for<remove_const_t<_Tp>>,
2265 __optional_hash<_Tp>,
2266 __hash_not_enabled<_Tp>>
2269 template<
typename _Tp>
2275#if __cpp_deduction_guides >= 201606
2276 template <
typename _Tp> optional(_Tp) -> optional<_Tp>;
2279#ifdef __cpp_lib_optional_range_support
2280 template<
typename _Tp>
2281 inline constexpr bool
2284#if __cpp_lib_optional >= 202506L
2285 template<
typename _Tp>
2287 ranges::enable_borrowed_range<optional<_Tp&>> =
true;
2291 template<
typename _Tp>
2292 inline constexpr range_format
2293 format_kind<optional<_Tp>> = range_format::disabled;
2297#undef _GLIBCXX_USE_CONSTRAINTS_FOR_OPTIONAL
2299_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