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
68namespace std _GLIBCXX_VISIBILITY(default)
70_GLIBCXX_BEGIN_NAMESPACE_VERSION
77 template<
typename _Tp>
91 explicit constexpr nullopt_t(_Construct)
noexcept { }
95 inline constexpr nullopt_t
nullopt { nullopt_t::_Construct::_Token };
97 template<
typename _Fn>
struct _Optional_func { _Fn& _M_f; };
104 class bad_optional_access :
public exception
107 bad_optional_access() =
default;
108 virtual ~bad_optional_access() =
default;
110#if __cpp_lib_constexpr_exceptions >= 202502L
113 const char* what() const noexcept
override
114 {
return "bad optional access"; }
119#if __cpp_lib_constexpr_exceptions >= 202502L
125 __throw_bad_optional_access()
126 { _GLIBCXX_THROW_OR_ABORT(bad_optional_access()); }
130 template <
typename _Tp>
131 struct _Optional_payload_base
133 using _Stored_type = remove_const_t<_Tp>;
135 _Optional_payload_base() =
default;
136 ~_Optional_payload_base() =
default;
138 template<
typename... _Args>
140 _Optional_payload_base(in_place_t __tag, _Args&&... __args)
141 : _M_payload(__tag, std::
forward<_Args>(__args)...),
145 template<
typename _Up,
typename... _Args>
147 _Optional_payload_base(std::initializer_list<_Up> __il,
149 : _M_payload(__il, std::
forward<_Args>(__args)...),
156 _Optional_payload_base(
bool ,
157 const _Optional_payload_base& __other)
159 if (__other._M_engaged)
160 this->_M_construct(__other._M_get());
166 _Optional_payload_base(
bool ,
167 _Optional_payload_base&& __other)
169 if (__other._M_engaged)
170 this->_M_construct(
std::move(__other._M_get()));
175 _Optional_payload_base(
const _Optional_payload_base&) =
default;
179 _Optional_payload_base(_Optional_payload_base&&) =
default;
181 _Optional_payload_base&
182 operator=(
const _Optional_payload_base&) =
default;
184 _Optional_payload_base&
185 operator=(_Optional_payload_base&&) =
default;
189 _M_copy_assign(
const _Optional_payload_base& __other)
191 if (this->_M_engaged && __other._M_engaged)
192 this->_M_get() = __other._M_get();
195 if (__other._M_engaged)
196 this->_M_construct(__other._M_get());
204 _M_move_assign(_Optional_payload_base&& __other)
205 noexcept(__and_v<is_nothrow_move_constructible<_Tp>,
206 is_nothrow_move_assignable<_Tp>>)
208 if (this->_M_engaged && __other._M_engaged)
209 this->_M_get() =
std::move(__other._M_get());
212 if (__other._M_engaged)
213 this->_M_construct(
std::move(__other._M_get()));
219 struct _Empty_byte { };
221 template<
typename _Up,
bool = is_trivially_destructible_v<_Up>>
224 constexpr _Storage() noexcept : _M_empty() { }
226 template<
typename... _Args>
228 _Storage(in_place_t, _Args&&... __args)
229 : _M_value(std::
forward<_Args>(__args)...)
232 template<
typename _Vp,
typename... _Args>
234 _Storage(std::initializer_list<_Vp> __il, _Args&&... __args)
235 : _M_value(__il, std::
forward<_Args>(__args)...)
238#if __cplusplus >= 202002L
239 template<
typename _Fn,
typename _Arg>
241 _Storage(_Optional_func<_Fn> __f, _Arg&& __arg)
247#if __cpp_concepts >= 202002L
248 ~_Storage() =
default;
252 ~_Storage()
requires (!is_trivially_destructible_v<_Up>)
255 _Storage(
const _Storage&) =
default;
256 _Storage(_Storage&&) =
default;
257 _Storage& operator=(
const _Storage&) =
default;
258 _Storage& operator=(_Storage&&) =
default;
261 _Empty_byte _M_empty;
265#if __cpp_concepts < 202002L
266 template<
typename _Up>
267 union _Storage<_Up, false>
269 constexpr _Storage() noexcept : _M_empty() { }
271 template<
typename... _Args>
273 _Storage(in_place_t, _Args&&... __args)
274 : _M_value(std::
forward<_Args>(__args)...)
277 template<
typename _Vp,
typename... _Args>
279 _Storage(std::initializer_list<_Vp> __il, _Args&&... __args)
280 : _M_value(__il, std::
forward<_Args>(__args)...)
283#if __cplusplus >= 202002L
284 template<
typename _Fn,
typename _Arg>
286 _Storage(_Optional_func<_Fn> __f, _Arg&& __arg)
293 _GLIBCXX20_CONSTEXPR ~_Storage() { }
295 _Storage(
const _Storage&) =
default;
296 _Storage(_Storage&&) =
default;
297 _Storage& operator=(
const _Storage&) =
default;
298 _Storage& operator=(_Storage&&) =
default;
300 _Empty_byte _M_empty;
305 _Storage<_Stored_type> _M_payload;
307 bool _M_engaged =
false;
309 template<
typename... _Args>
311 _M_construct(_Args&&... __args)
312 noexcept(is_nothrow_constructible_v<_Stored_type, _Args...>)
316 this->_M_engaged =
true;
320 _M_destroy() noexcept
323 _M_payload._M_value.~_Stored_type();
326#if __cplusplus >= 202002L
327 template<
typename _Fn,
typename _Up>
329 _M_apply(_Optional_func<_Fn> __f, _Up&& __x)
343 {
return this->_M_payload._M_value; }
346 _M_get() const noexcept
347 {
return this->_M_payload._M_value; }
353 if (this->_M_engaged)
356 this->_M_engaged =
false;
361 template <
typename _Tp,
363 is_trivially_destructible_v<_Tp>,
365 is_trivially_copy_assignable_v<_Tp>
366 && is_trivially_copy_constructible_v<_Tp>,
368 is_trivially_move_assignable_v<_Tp>
369 && is_trivially_move_constructible_v<_Tp>>
370 struct _Optional_payload;
373 template <
typename _Tp>
374 struct _Optional_payload<_Tp, true, true, true>
375 : _Optional_payload_base<_Tp>
377 using _Optional_payload_base<_Tp>::_Optional_payload_base;
379 _Optional_payload() =
default;
383 template <
typename _Tp>
384 struct _Optional_payload<_Tp, true, false, true>
385 : _Optional_payload_base<_Tp>
387 using _Optional_payload_base<_Tp>::_Optional_payload_base;
389 _Optional_payload() =
default;
390 ~_Optional_payload() =
default;
391 _Optional_payload(
const _Optional_payload&) =
default;
392 _Optional_payload(_Optional_payload&&) =
default;
393 _Optional_payload& operator=(_Optional_payload&&) =
default;
398 operator=(
const _Optional_payload& __other)
400 this->_M_copy_assign(__other);
406 template <
typename _Tp>
407 struct _Optional_payload<_Tp, true, true, false>
408 : _Optional_payload_base<_Tp>
410 using _Optional_payload_base<_Tp>::_Optional_payload_base;
412 _Optional_payload() =
default;
413 ~_Optional_payload() =
default;
414 _Optional_payload(
const _Optional_payload&) =
default;
415 _Optional_payload(_Optional_payload&&) =
default;
416 _Optional_payload& operator=(
const _Optional_payload&) =
default;
421 operator=(_Optional_payload&& __other)
422 noexcept(__and_v<is_nothrow_move_constructible<_Tp>,
423 is_nothrow_move_assignable<_Tp>>)
425 this->_M_move_assign(
std::move(__other));
431 template <
typename _Tp>
432 struct _Optional_payload<_Tp, true, false, false>
433 : _Optional_payload_base<_Tp>
435 using _Optional_payload_base<_Tp>::_Optional_payload_base;
437 _Optional_payload() =
default;
438 ~_Optional_payload() =
default;
439 _Optional_payload(
const _Optional_payload&) =
default;
440 _Optional_payload(_Optional_payload&&) =
default;
445 operator=(
const _Optional_payload& __other)
447 this->_M_copy_assign(__other);
454 operator=(_Optional_payload&& __other)
455 noexcept(__and_v<is_nothrow_move_constructible<_Tp>,
456 is_nothrow_move_assignable<_Tp>>)
458 this->_M_move_assign(
std::move(__other));
464 template <
typename _Tp,
bool _Copy,
bool _Move>
465 struct _Optional_payload<_Tp, false, _Copy, _Move>
466 : _Optional_payload<_Tp, true, false, false>
469 using _Optional_payload<_Tp,
true,
false,
false>::_Optional_payload;
470 _Optional_payload() =
default;
471 _Optional_payload(
const _Optional_payload&) =
default;
472 _Optional_payload(_Optional_payload&&) =
default;
473 _Optional_payload& operator=(
const _Optional_payload&) =
default;
474 _Optional_payload& operator=(_Optional_payload&&) =
default;
477 _GLIBCXX20_CONSTEXPR ~_Optional_payload() { this->_M_reset(); }
498 template<
typename _Tp,
499 bool = is_trivially_copy_constructible_v<_Tp>,
500 bool = is_trivially_move_constructible_v<_Tp>>
501 struct _Optional_base
504 constexpr _Optional_base() =
default;
507 template<
typename... _Args,
508 enable_if_t<is_constructible_v<_Tp, _Args...>,
bool> =
false>
510 _Optional_base(in_place_t, _Args&&... __args)
511 : _M_payload(in_place, std::
forward<_Args>(__args)...)
514 template<
typename _Up,
typename... _Args,
516 initializer_list<_Up>&,
517 _Args...>,
bool> =
false>
519 _Optional_base(in_place_t,
520 initializer_list<_Up> __il,
522 : _M_payload(in_place, __il, std::
forward<_Args>(__args)...)
527 _Optional_base(
const _Optional_base& __other)
528 noexcept(is_nothrow_copy_constructible_v<_Tp>)
529 : _M_payload(__other._M_payload._M_engaged, __other._M_payload)
533 _Optional_base(_Optional_base&& __other)
534 noexcept(is_nothrow_move_constructible_v<_Tp>)
535 : _M_payload(__other._M_payload._M_engaged,
536 std::move(__other._M_payload))
539#if __cpp_concepts >= 202002L
542 constexpr _Optional_base(
const _Optional_base&)
543 requires is_trivially_copy_constructible_v<_Tp> =
default;
545 constexpr _Optional_base(_Optional_base&&)
546 requires is_trivially_move_constructible_v<_Tp> = default;
550 _Optional_base& operator=(
const _Optional_base&) =
default;
551 _Optional_base& operator=(_Optional_base&&) =
default;
553 _Optional_payload<_Tp> _M_payload;
557 using _Stored_type = remove_const_t<_Tp>;
561 template<
typename... _Args>
563 _M_construct(_Args&&... __args)
564 noexcept(is_nothrow_constructible_v<_Stored_type, _Args...>)
570 _M_destruct() noexcept
571 { _M_payload._M_destroy(); }
576 { _M_payload._M_reset(); }
578 constexpr bool _M_is_engaged() const noexcept
579 {
return _M_payload._M_engaged; }
584 {
return _M_payload._M_get(); }
587 _M_get() const noexcept
588 {
return _M_payload._M_get(); }
591#if __cpp_concepts < 202002L
602 template<
typename _Tp,
typename _Dp>
603 class _Optional_base_impl
606 using _Stored_type = remove_const_t<_Tp>;
610 template<
typename... _Args>
612 _M_construct(_Args&&... __args)
613 noexcept(is_nothrow_constructible_v<_Stored_type, _Args...>)
615 static_cast<_Dp*
>(
this)->_M_payload._M_construct(
620 _M_destruct() noexcept
621 {
static_cast<_Dp*
>(
this)->_M_payload._M_destroy(); }
626 {
static_cast<_Dp*
>(
this)->_M_payload._M_reset(); }
628 constexpr bool _M_is_engaged() const noexcept
629 {
return static_cast<const _Dp*
>(
this)->_M_payload._M_engaged; }
634 {
return static_cast<_Dp*
>(
this)->_M_payload._M_get(); }
637 _M_get() const noexcept
638 {
return static_cast<const _Dp*
>(
this)->_M_payload._M_get(); }
641 template<
typename _Tp>
642 struct _Optional_base<_Tp, false, true>
643 : _Optional_base_impl<_Tp, _Optional_base<_Tp>>
646 constexpr _Optional_base() =
default;
649 template<
typename... _Args,
650 enable_if_t<is_constructible_v<_Tp, _Args...>,
bool> =
false>
652 _Optional_base(in_place_t, _Args&&... __args)
653 : _M_payload(in_place, std::
forward<_Args>(__args)...)
656 template<
typename _Up,
typename... _Args,
658 initializer_list<_Up>&,
659 _Args...>,
bool> =
false>
661 _Optional_base(in_place_t,
662 initializer_list<_Up> __il,
664 : _M_payload(in_place, __il, std::
forward<_Args>(__args)...)
668 constexpr _Optional_base(
const _Optional_base& __other)
669 : _M_payload(__other._M_payload._M_engaged, __other._M_payload)
672 constexpr _Optional_base(_Optional_base&& __other) =
default;
675 _Optional_base& operator=(
const _Optional_base&) =
default;
676 _Optional_base& operator=(_Optional_base&&) =
default;
678 _Optional_payload<_Tp> _M_payload;
681 template<
typename _Tp>
682 struct _Optional_base<_Tp, true, false>
683 : _Optional_base_impl<_Tp, _Optional_base<_Tp>>
686 constexpr _Optional_base() =
default;
689 template<
typename... _Args,
690 enable_if_t<is_constructible_v<_Tp, _Args...>,
bool> =
false>
692 _Optional_base(in_place_t, _Args&&... __args)
693 : _M_payload(in_place, std::
forward<_Args>(__args)...)
696 template<
typename _Up,
typename... _Args,
699 _Args...>,
bool> =
false>
701 _Optional_base(in_place_t,
704 : _M_payload(in_place, __il, std::
forward<_Args>(__args)...)
708 constexpr _Optional_base(
const _Optional_base& __other) =
default;
711 _Optional_base(_Optional_base&& __other)
712 noexcept(is_nothrow_move_constructible_v<_Tp>)
713 : _M_payload(__other._M_payload._M_engaged,
714 std::
move(__other._M_payload))
718 _Optional_base& operator=(
const _Optional_base&) =
default;
719 _Optional_base& operator=(_Optional_base&&) =
default;
721 _Optional_payload<_Tp> _M_payload;
724 template<
typename _Tp>
725 struct _Optional_base<_Tp, true, true>
726 : _Optional_base_impl<_Tp, _Optional_base<_Tp>>
729 constexpr _Optional_base() =
default;
732 template<
typename... _Args,
733 enable_if_t<is_constructible_v<_Tp, _Args...>,
bool> =
false>
735 _Optional_base(in_place_t, _Args&&... __args)
736 : _M_payload(in_place, std::
forward<_Args>(__args)...)
739 template<
typename _Up,
typename... _Args,
742 _Args...>,
bool> =
false>
744 _Optional_base(in_place_t,
747 : _M_payload(in_place, __il, std::
forward<_Args>(__args)...)
751 constexpr _Optional_base(
const _Optional_base& __other) =
default;
752 constexpr _Optional_base(_Optional_base&& __other) =
default;
755 _Optional_base& operator=(
const _Optional_base&) =
default;
756 _Optional_base& operator=(_Optional_base&&) =
default;
758 _Optional_payload<_Tp> _M_payload;
762 template<
typename _Tp>
763 inline constexpr bool __is_optional_v =
false;
764 template<
typename _Tp>
765 inline constexpr bool __is_optional_v<optional<_Tp>> =
true;
767 template<
typename _Tp,
typename _Wp>
768 using __converts_from_any_cvref = __or_<
775 template<
typename _Tp,
typename _Up>
776 using __converts_from_optional
777 = __converts_from_any_cvref<_Tp, optional<_Up>>;
779 template<
typename _Tp,
typename _Up>
780 using __assigns_from_optional =
781 __or_<is_assignable<_Tp&, const optional<_Up>&>,
786#if __cpp_concepts && __cpp_conditional_explicit && __glibcxx_remove_cvref
787# define _GLIBCXX_USE_CONSTRAINTS_FOR_OPTIONAL 1
790 template<
typename _Tp>
791 inline constexpr bool __is_valid_contained_type_for_optional =
793#if __cpp_lib_optional >= 202506L
794 is_lvalue_reference_v<_Tp> ||
796 (is_object_v<_Tp> && is_destructible_v<_Tp> && !is_array_v<_Tp>)
804 template<
typename _Tp>
806 :
private _Optional_base<_Tp>,
807 private _Enable_copy_move<
809 is_copy_constructible_v<_Tp>,
811 __and_v<is_copy_constructible<_Tp>, is_copy_assignable<_Tp>>,
813 is_move_constructible_v<_Tp>,
815 __and_v<is_move_constructible<_Tp>, is_move_assignable<_Tp>>,
819 static_assert(__is_valid_contained_type_for_optional<_Tp>);
822 using _Base = _Optional_base<_Tp>;
830#ifdef _GLIBCXX_USE_CONSTRAINTS_FOR_OPTIONAL
831 template<
typename _From,
typename = remove_cv_t<_Tp>>
832 static constexpr bool __not_constructing_bool_from_optional
837 template<
typename _From>
838 static constexpr bool
839 __not_constructing_bool_from_optional<_From, bool>
840 = !__is_optional_v<remove_cvref_t<_From>>;
846 template<
typename _From,
typename = remove_cv_t<_Tp>>
847 static constexpr bool __construct_from_contained_value
848 = !__converts_from_optional<_Tp, _From>::value;
852 template<
typename _From>
853 static constexpr bool __construct_from_contained_value<_From, bool>
856 template<
typename _From,
typename = remove_cv_t<_Tp>>
857 struct __not_constructing_bool_from_optional
861 template<
typename _From>
862 struct __not_constructing_bool_from_optional<_From, bool>
863 : bool_constant<!__is_optional_v<__remove_cvref_t<_From>>>
866 template<
typename _From,
typename = remove_cv_t<_Tp>>
867 struct __construct_from_contained_value
868 : __not_<__converts_from_optional<_Tp, _From>>
871 template<
typename _From>
872 struct __construct_from_contained_value<_From, bool>
876 template<
typename _Up>
877 using __not_self = __not_<is_same<optional, __remove_cvref_t<_Up>>>;
878 template<
typename _Up>
879 using __not_tag = __not_<is_same<in_place_t, __remove_cvref_t<_Up>>>;
880 template<
typename... _Cond>
881 using _Requires =
enable_if_t<__and_v<_Cond...>,
bool>;
885 using value_type = _Tp;
886#ifdef __cpp_lib_optional_range_support
887 using iterator = __gnu_cxx::__normal_iterator<_Tp*, optional>;
888 using const_iterator = __gnu_cxx::__normal_iterator<const _Tp*, optional>;
891 constexpr optional() noexcept { }
893 constexpr optional(nullopt_t)
noexcept { }
896#ifdef _GLIBCXX_USE_CONSTRAINTS_FOR_OPTIONAL
897 template<
typename _Up = remove_cv_t<_Tp>>
898 requires (!is_same_v<optional, remove_cvref_t<_Up>>)
899 && (!is_same_v<in_place_t, remove_cvref_t<_Up>>)
900 && is_constructible_v<_Tp, _Up>
901 && __not_constructing_bool_from_optional<_Up>
902 constexpr explicit(!is_convertible_v<_Up, _Tp>)
904 noexcept(is_nothrow_constructible_v<_Tp, _Up>)
905 : _Base(std::in_place, std::
forward<_Up>(__t)) { }
907 template<
typename _Up>
908 requires (!is_same_v<_Tp, _Up>)
909 && is_constructible_v<_Tp, const _Up&>
910 && __construct_from_contained_value<_Up>
911 constexpr explicit(!is_convertible_v<const _Up&, _Tp>)
912 optional(
const optional<_Up>& __t)
913 noexcept(is_nothrow_constructible_v<_Tp, const _Up&>)
916 emplace(__t._M_fwd());
919 template<
typename _Up>
920 requires (!is_same_v<_Tp, _Up>)
921 && is_constructible_v<_Tp, _Up>
922 && __construct_from_contained_value<_Up>
923 constexpr explicit(!is_convertible_v<_Up, _Tp>)
924 optional(optional<_Up>&& __t)
925 noexcept(is_nothrow_constructible_v<_Tp, _Up>)
931 template<
typename... _Args>
932 requires is_constructible_v<_Tp, _Args...>
934 optional(in_place_t, _Args&&... __args)
935 noexcept(is_nothrow_constructible_v<_Tp, _Args...>)
936 : _Base(std::in_place, std::
forward<_Args>(__args)...)
939 template<
typename _Up,
typename... _Args>
940 requires is_constructible_v<_Tp, initializer_list<_Up>&, _Args...>
942 optional(in_place_t, initializer_list<_Up> __il, _Args&&... __args)
943 noexcept(is_nothrow_constructible_v<_Tp, initializer_list<_Up>&,
945 : _Base(std::in_place, __il, std::
forward<_Args>(__args)...)
948 template<
typename _Up = remove_cv_t<_Tp>,
949 _Requires<__not_self<_Up>, __not_tag<_Up>,
950 is_constructible<_Tp, _Up>,
951 is_convertible<_Up, _Tp>,
952 __not_constructing_
bool_from_optional<_Up>> = true>
955 noexcept(is_nothrow_constructible_v<_Tp, _Up>)
956 : _Base(std::in_place, std::
forward<_Up>(__t)) { }
958 template<
typename _Up = remove_cv_t<_Tp>,
959 _Requires<__not_self<_Up>, __not_tag<_Up>,
960 is_constructible<_Tp, _Up>,
961 __not_<is_convertible<_Up, _Tp>>,
962 __not_constructing_
bool_from_optional<_Up>> = false>
965 noexcept(is_nothrow_constructible_v<_Tp, _Up>)
966 : _Base(std::in_place, std::
forward<_Up>(__t)) { }
968 template<
typename _Up,
969 _Requires<__not_<is_same<_Tp, _Up>>,
970 is_constructible<_Tp, const _Up&>,
971 is_convertible<const _Up&, _Tp>,
972 __construct_from_contained_value<_Up>> =
true>
974 optional(
const optional<_Up>& __t)
975 noexcept(is_nothrow_constructible_v<_Tp, const _Up&>)
978 emplace(__t._M_fwd());
981 template<
typename _Up,
982 _Requires<__not_<is_same<_Tp, _Up>>,
983 is_constructible<_Tp, const _Up&>,
984 __not_<is_convertible<const _Up&, _Tp>>,
985 __construct_from_contained_value<_Up>> =
false>
987 optional(
const optional<_Up>& __t)
988 noexcept(is_nothrow_constructible_v<_Tp, const _Up&>)
991 emplace(__t._M_fwd());
994 template<
typename _Up,
995 _Requires<__not_<is_same<_Tp, _Up>>,
996 is_constructible<_Tp, _Up>,
997 is_convertible<_Up, _Tp>,
998 __construct_from_contained_value<_Up>> =
true>
1000 optional(optional<_Up>&& __t)
1001 noexcept(is_nothrow_constructible_v<_Tp, _Up>)
1007 template<
typename _Up,
1008 _Requires<__not_<is_same<_Tp, _Up>>,
1009 is_constructible<_Tp, _Up>,
1010 __not_<is_convertible<_Up, _Tp>>,
1011 __construct_from_contained_value<_Up>> =
false>
1013 optional(optional<_Up>&& __t)
1014 noexcept(is_nothrow_constructible_v<_Tp, _Up>)
1020 template<
typename... _Args,
1021 _Requires<is_constructible<_Tp, _Args...>> =
false>
1023 optional(in_place_t, _Args&&... __args)
1024 noexcept(is_nothrow_constructible_v<_Tp, _Args...>)
1025 : _Base(std::in_place, std::
forward<_Args>(__args)...) { }
1027 template<
typename _Up,
typename... _Args,
1028 _Requires<is_constructible<_Tp,
1029 initializer_list<_Up>&,
1032 optional(in_place_t, initializer_list<_Up> __il, _Args&&... __args)
1033 noexcept(is_nothrow_constructible_v<_Tp, initializer_list<_Up>&,
1035 : _Base(std::in_place, __il, std::
forward<_Args>(__args)...) { }
1039 _GLIBCXX20_CONSTEXPR optional&
1040 operator=(nullopt_t)
noexcept
1046 template<
typename _Up = remove_cv_t<_Tp>>
1047#ifdef _GLIBCXX_USE_CONSTRAINTS_FOR_OPTIONAL
1048 requires (!is_same_v<optional, remove_cvref_t<_Up>>)
1049 && (!(is_scalar_v<_Tp> && is_same_v<_Tp,
decay_t<_Up>>))
1050 && is_constructible_v<_Tp, _Up>
1051 && is_assignable_v<_Tp&, _Up>
1055 __not_<__and_<is_scalar<_Tp>,
1056 is_same<_Tp, decay_t<_Up>>>>,
1057 is_constructible<_Tp, _Up>,
1058 is_assignable<_Tp&, _Up>>,
1061 operator=(_Up&& __u)
1062 noexcept(__and_v<is_nothrow_constructible<_Tp, _Up>,
1063 is_nothrow_assignable<_Tp&, _Up>>)
1065 if (this->_M_is_engaged())
1073 template<
typename _Up>
1074#ifdef _GLIBCXX_USE_CONSTRAINTS_FOR_OPTIONAL
1075 requires (!is_same_v<_Tp, _Up>)
1076 && is_constructible_v<_Tp, const _Up&>
1077 && is_assignable_v<_Tp&, const _Up&>
1078 && (!__converts_from_optional<_Tp, _Up>::value)
1079 && (!__assigns_from_optional<_Tp, _Up>::value)
1083 is_constructible<_Tp, const _Up&>,
1084 is_assignable<_Tp&, const _Up&>,
1085 __not_<__converts_from_optional<_Tp, _Up>>,
1086 __not_<__assigns_from_optional<_Tp, _Up>>>,
1089 operator=(
const optional<_Up>& __u)
1090 noexcept(__and_v<is_nothrow_constructible<_Tp, const _Up&>,
1091 is_nothrow_assignable<_Tp&, const _Up&>>)
1095 if (this->_M_is_engaged())
1096 this->_M_get() = __u._M_fwd();
1098 this->_M_construct(__u._M_fwd());
1107 template<
typename _Up>
1108#ifdef _GLIBCXX_USE_CONSTRAINTS_FOR_OPTIONAL
1109 requires (!is_same_v<_Tp, _Up>)
1110 && is_constructible_v<_Tp, _Up>
1111 && is_assignable_v<_Tp&, _Up>
1112 && (!__converts_from_optional<_Tp, _Up>::value)
1113 && (!__assigns_from_optional<_Tp, _Up>::value)
1117 is_constructible<_Tp, _Up>,
1118 is_assignable<_Tp&, _Up>,
1119 __not_<__converts_from_optional<_Tp, _Up>>,
1120 __not_<__assigns_from_optional<_Tp, _Up>>>,
1123 operator=(optional<_Up>&& __u)
1124 noexcept(__and_v<is_nothrow_constructible<_Tp, _Up>,
1125 is_nothrow_assignable<_Tp&, _Up>>)
1129 if (this->_M_is_engaged())
1130 this->_M_get() =
std::move(__u)._M_fwd();
1132 this->_M_construct(
std::move(__u)._M_fwd());
1142 template<
typename... _Args>
1143 _GLIBCXX20_CONSTEXPR
1144 enable_if_t<is_constructible_v<_Tp, _Args...>, _Tp&>
1145 emplace(_Args&&... __args)
1146 noexcept(is_nothrow_constructible_v<_Tp, _Args...>)
1150 return this->_M_get();
1153 template<
typename _Up,
typename... _Args>
1154 _GLIBCXX20_CONSTEXPR
1157 emplace(initializer_list<_Up> __il, _Args&&... __args)
1158 noexcept(is_nothrow_constructible_v<_Tp, initializer_list<_Up>&,
1163 return this->_M_get();
1169 _GLIBCXX20_CONSTEXPR
void
1170 swap(optional& __other)
1171 noexcept(is_nothrow_move_constructible_v<_Tp>
1172 && is_nothrow_swappable_v<_Tp>)
1176 if (this->_M_is_engaged() && __other._M_is_engaged())
1177 swap(this->_M_get(), __other._M_get());
1178 else if (this->_M_is_engaged())
1180 __other._M_construct(
std::move(this->_M_get()));
1181 this->_M_destruct();
1183 else if (__other._M_is_engaged())
1185 this->_M_construct(
std::move(__other._M_get()));
1186 __other._M_destruct();
1190#ifdef __cpp_lib_optional_range_support
1192 constexpr iterator
begin() noexcept
1199 constexpr const_iterator
begin() const noexcept
1201 return const_iterator(
1206 constexpr iterator
end() noexcept
1208 return begin() + has_value();
1211 constexpr const_iterator
end() const noexcept
1213 return begin() + has_value();
1218 constexpr const _Tp*
1219 operator->() const noexcept
1221 __glibcxx_assert(this->_M_is_engaged());
1226 operator->() noexcept
1228 __glibcxx_assert(this->_M_is_engaged());
1232 constexpr const _Tp&
1235 __glibcxx_assert(this->_M_is_engaged());
1236 return this->_M_get();
1242 __glibcxx_assert(this->_M_is_engaged());
1243 return this->_M_get();
1249 __glibcxx_assert(this->_M_is_engaged());
1253 constexpr const _Tp&&
1256 __glibcxx_assert(this->_M_is_engaged());
1260 constexpr explicit operator bool() const noexcept
1261 {
return this->_M_is_engaged(); }
1263 constexpr bool has_value() const noexcept
1264 {
return this->_M_is_engaged(); }
1266 constexpr const _Tp&
1269 if (this->_M_is_engaged())
1270 return this->_M_get();
1271 __throw_bad_optional_access();
1277 if (this->_M_is_engaged())
1278 return this->_M_get();
1279 __throw_bad_optional_access();
1285 if (this->_M_is_engaged())
1287 __throw_bad_optional_access();
1290 constexpr const _Tp&&
1293 if (this->_M_is_engaged())
1295 __throw_bad_optional_access();
1300 template<
typename _Up = remove_cv_t<_Tp>>
1301 constexpr remove_cv_t<_Tp>
1302 value_or(_Up&& __u)
const&
1304 using _Xp = remove_cv_t<_Tp>;
1305 static_assert(is_convertible_v<const _Tp&, _Xp>);
1306 static_assert(is_convertible_v<_Up, _Xp>);
1308 if (this->_M_is_engaged())
1309 return this->_M_get();
1313 template<
typename _Up = remove_cv_t<_Tp>>
1314 constexpr remove_cv_t<_Tp>
1315 value_or(_Up&& __u) &&
1317 using _Xp = remove_cv_t<_Tp>;
1318 static_assert(is_convertible_v<_Tp, _Xp>);
1319 static_assert(is_convertible_v<_Up, _Xp>);
1321 if (this->_M_is_engaged())
1326#if __cpp_lib_optional >= 202110L
1329 template<
typename _Fn>
1331 and_then(_Fn&& __f) &
1333 using _Up = remove_cvref_t<invoke_result_t<_Fn, _Tp&>>;
1334 static_assert(__is_optional_v<_Up>,
1335 "the function passed to std::optional<T>::and_then "
1336 "must return a std::optional");
1343 template<
typename _Fn>
1345 and_then(_Fn&& __f)
const &
1347 using _Up = remove_cvref_t<invoke_result_t<_Fn, const _Tp&>>;
1348 static_assert(__is_optional_v<_Up>,
1349 "the function passed to std::optional<T>::and_then "
1350 "must return a std::optional");
1357 template<
typename _Fn>
1359 and_then(_Fn&& __f) &&
1361 using _Up = remove_cvref_t<invoke_result_t<_Fn, _Tp>>;
1362 static_assert(__is_optional_v<_Up>,
1363 "the function passed to std::optional<T>::and_then "
1364 "must return a std::optional");
1371 template<
typename _Fn>
1373 and_then(_Fn&& __f)
const &&
1375 using _Up = remove_cvref_t<invoke_result_t<_Fn, const _Tp>>;
1376 static_assert(__is_optional_v<_Up>,
1377 "the function passed to std::optional<T>::and_then "
1378 "must return a std::optional");
1385 template<
typename _Fn>
1387 transform(_Fn&& __f) &
1389 using _Up = remove_cv_t<invoke_result_t<_Fn, _Tp&>>;
1391 return optional<_Up>(_Optional_func<_Fn>{__f}, _M_get());
1393 return optional<_Up>();
1396 template<
typename _Fn>
1398 transform(_Fn&& __f)
const &
1400 using _Up = remove_cv_t<invoke_result_t<_Fn, const _Tp&>>;
1402 return optional<_Up>(_Optional_func<_Fn>{__f}, _M_get());
1404 return optional<_Up>();
1407 template<
typename _Fn>
1409 transform(_Fn&& __f) &&
1411 using _Up = remove_cv_t<invoke_result_t<_Fn, _Tp>>;
1413 return optional<_Up>(_Optional_func<_Fn>{__f},
std::move(_M_get()));
1415 return optional<_Up>();
1418 template<
typename _Fn>
1420 transform(_Fn&& __f)
const &&
1422 using _Up = remove_cv_t<invoke_result_t<_Fn, const _Tp>>;
1424 return optional<_Up>(_Optional_func<_Fn>{__f},
std::move(_M_get()));
1426 return optional<_Up>();
1429 template<
typename _Fn>
requires invocable<_Fn> && copy_constructible<_Tp>
1431 or_else(_Fn&& __f)
const&
1433 using _Up = invoke_result_t<_Fn>;
1434 static_assert(is_same_v<remove_cvref_t<_Up>, optional>,
1435 "the function passed to std::optional<T>::or_else "
1436 "must return a std::optional<T>");
1444 template<
typename _Fn>
requires invocable<_Fn> && move_constructible<_Tp>
1446 or_else(_Fn&& __f) &&
1448 using _Up = invoke_result_t<_Fn>;
1449 static_assert(is_same_v<remove_cvref_t<_Up>, optional>,
1450 "the function passed to std::optional<T>::or_else "
1451 "must return a std::optional<T>");
1460 _GLIBCXX20_CONSTEXPR
void reset() noexcept { this->_M_reset(); }
1463 using _Base::_M_get;
1465 [[__gnu__::__always_inline__]]
1468 {
return _M_get(); }
1470 [[__gnu__::__always_inline__]]
1472 _M_fwd() &&
noexcept
1475 [[__gnu__::__always_inline__]]
1476 constexpr const _Tp&
1477 _M_fwd() const& noexcept
1478 {
return _M_get(); }
1480 [[__gnu__::__always_inline__]]
1481 constexpr const _Tp&&
1482 _M_fwd() const&& noexcept
1485 template<
typename _Up>
friend class optional;
1487#if __cpp_lib_optional >= 202110L
1488 template<
typename _Fn,
typename _Value>
1490 optional(_Optional_func<_Fn> __f, _Value&& __v)
1497#if __cpp_lib_optional >= 202506L
1498 template<
typename _Tp>
1499 class optional<_Tp&>;
1501 template<
typename _Tp>
1502 constexpr bool __is_optional_ref_v =
false;
1504 template<
typename _Tp>
1505 constexpr bool __is_optional_ref_v<optional<_Tp&>> =
true;
1507 template<
typename _Tp>
1508 struct __optional_ref_base
1511#ifdef __cpp_lib_optional_range_support
1512 template<
typename _Tp>
1513 struct __optional_ref_base<_Tp[]>
1516 template<
typename _Tp>
1517 requires is_object_v<_Tp>
1518 struct __optional_ref_base<_Tp>
1520 using iterator = __gnu_cxx::__normal_iterator<_Tp*, optional<_Tp&>>;
1524 template<
typename _Tp>
1525 class optional<_Tp&> :
public __optional_ref_base<_Tp>
1527 static_assert(__is_valid_contained_type_for_optional<_Tp&>);
1533 constexpr optional() noexcept = default;
1534 constexpr optional(nullopt_t) noexcept : optional() {}
1535 constexpr optional(
const optional&)
noexcept =
default;
1537 template<
typename _Arg>
1538 requires is_constructible_v<_Tp&, _Arg>
1539 && (!reference_constructs_from_temporary_v<_Tp&, _Arg>)
1541 optional(in_place_t, _Arg&& __arg)
1546 template<
typename _Up>
1547 requires (!is_same_v<remove_cvref_t<_Up>, optional>)
1548 && (!is_same_v<remove_cvref_t<_Up>, in_place_t>)
1549 && is_constructible_v<_Tp&, _Up>
1550 && (!reference_constructs_from_temporary_v<_Tp&, _Up>)
1551 explicit(!is_convertible_v<_Up, _Tp&>)
1554 noexcept(is_nothrow_constructible_v<_Tp&, _Up>)
1559 template<
typename _Up>
1560 requires (!is_same_v<remove_cvref_t<_Up>, optional>)
1561 && (!is_same_v<remove_cvref_t<_Up>, in_place_t>)
1562 && is_constructible_v<_Tp&, _Up>
1563 && reference_constructs_from_temporary_v<_Tp&, _Up>
1564 explicit(!is_convertible_v<_Up, _Tp&>)
1566 optional(_Up&& __u) =
delete;
1569 template<
typename _Up>
1570 requires (!is_same_v<remove_cv_t<_Tp>, optional<_Up>>)
1571 && (!is_same_v<_Tp&, _Up>)
1572 && is_constructible_v<_Tp&, _Up&>
1573 && (!reference_constructs_from_temporary_v<_Tp&, _Up&>)
1574 explicit(!is_convertible_v<_Up&, _Tp&>)
1576 optional(optional<_Up>& __rhs)
1577 noexcept(is_nothrow_constructible_v<_Tp&, _Up&>)
1580 __convert_ref_init_val(__rhs._M_fwd());
1583 template<
typename _Up>
1584 requires (!is_same_v<remove_cv_t<_Tp>, optional<_Up>>)
1585 && (!is_same_v<_Tp&, _Up>)
1586 && is_constructible_v<_Tp&, _Up&>
1587 && reference_constructs_from_temporary_v<_Tp&, _Up&>
1588 explicit(!is_convertible_v<_Up&, _Tp&>)
1590 optional(optional<_Up>& __rhs) =
delete;
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&, const _Up&>
1597 && (!reference_constructs_from_temporary_v<_Tp&, const _Up&>)
1598 explicit(!is_convertible_v<const _Up&, _Tp&>)
1600 optional(
const optional<_Up>& __rhs)
1601 noexcept(is_nothrow_constructible_v<_Tp&, _Up&>)
1604 __convert_ref_init_val(__rhs._M_fwd());
1607 template<
typename _Up>
1608 requires (!is_same_v<remove_cv_t<_Tp>, optional<_Up>>)
1609 && (!is_same_v<_Tp&, _Up>)
1610 && is_constructible_v<_Tp&, const _Up&>
1611 && reference_constructs_from_temporary_v<_Tp&, const _Up&>
1612 explicit(!is_convertible_v<const _Up&, _Tp&>)
1614 optional(
const optional<_Up>& __rhs) =
delete;
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&, _Up>
1621 && (!reference_constructs_from_temporary_v<_Tp&, _Up>)
1622 explicit(!is_convertible_v<_Up, _Tp&>)
1624 optional(optional<_Up>&& __rhs)
1625 noexcept(is_nothrow_constructible_v<_Tp&, _Up>)
1628 __convert_ref_init_val(
std::move(__rhs)._M_fwd());
1631 template<
typename _Up>
1632 requires (!is_same_v<remove_cv_t<_Tp>, optional<_Up>>)
1633 && (!is_same_v<_Tp&, _Up>)
1634 && is_constructible_v<_Tp&, _Up>
1635 && reference_constructs_from_temporary_v<_Tp&, _Up>
1636 explicit(!is_convertible_v<_Up, _Tp&>)
1638 optional(optional<_Up>&& __rhs) =
delete;
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&, const _Up>
1645 && (!reference_constructs_from_temporary_v<_Tp&, _Up>)
1646 explicit(!is_convertible_v<const _Up, _Tp&>)
1648 optional(
const optional<_Up>&& __rhs)
1649 noexcept(is_nothrow_constructible_v<_Tp&, const _Up>)
1652 __convert_ref_init_val(
std::move(__rhs)._M_fwd());
1655 template<
typename _Up>
1656 requires (!is_same_v<remove_cv_t<_Tp>, optional<_Up>>)
1657 && (!is_same_v<_Tp&, _Up>)
1658 && is_constructible_v<_Tp&, const _Up>
1659 && reference_constructs_from_temporary_v<_Tp&, const _Up>
1660 explicit(!is_convertible_v<const _Up, _Tp&>)
1662 optional(
const optional<_Up>&& __rhs) =
delete;
1664 constexpr ~optional() =
default;
1667 constexpr optional& operator=(nullopt_t)
noexcept
1673 constexpr optional& operator=(
const optional&)
noexcept =
default;
1675 template<
typename _Up>
1676 requires is_constructible_v<_Tp&, _Up>
1677 && (!reference_constructs_from_temporary_v<_Tp&, _Up>)
1680 noexcept(is_nothrow_constructible_v<_Tp&, _Up>)
1689 constexpr void swap(optional& __rhs)
noexcept
1690 { std::swap(_M_val, __rhs._M_val); }
1692#ifdef __cpp_lib_optional_range_support
1694 constexpr auto begin() const noexcept
1695 requires is_object_v<_Tp> && (!is_unbounded_array_v<_Tp>)
1696 {
return __gnu_cxx::__normal_iterator<_Tp*, optional>(_M_val); }
1698 constexpr auto end() const noexcept
1699 requires is_object_v<_Tp> && (!is_unbounded_array_v<_Tp>)
1700 {
return begin() + has_value(); }
1704 constexpr _Tp* operator->() const noexcept
1706 __glibcxx_assert(_M_val);
1710 constexpr _Tp&
operator*() const noexcept
1712 __glibcxx_assert(_M_val);
1716 constexpr explicit operator bool() const noexcept
1721 constexpr bool has_value() const noexcept
1726 constexpr _Tp& value()
const
1730 __throw_bad_optional_access();
1735 template<
typename _Up = remove_cv_t<_Tp>>
1736 requires is_object_v<_Tp> && (!is_array_v<_Tp>)
1738 value_or(_Up&& __u)
const
1740 using _Xp = remove_cv_t<_Tp>;
1741 static_assert(is_convertible_v<_Tp&, _Xp>);
1742 static_assert(is_convertible_v<_Up, _Xp>);
1749 template<
typename _Fn>
1751 and_then(_Fn&& __f)
const
1753 using _Up = remove_cvref_t<invoke_result_t<_Fn, _Tp&>>;
1754 static_assert(__is_optional_v<_Up>,
1755 "the function passed to std::optional<T&>::and_then "
1756 "must return a std::optional");
1763 template<
typename _Fn>
1765 optional<remove_cv_t<invoke_result_t<_Fn, _Tp&>>>
1766 transform(_Fn&& __f)
const
1768 using _Up = remove_cv_t<invoke_result_t<_Fn, _Tp&>>;
1770 return optional<_Up>(_Optional_func<_Fn>{__f}, *_M_val);
1772 return optional<_Up>();
1775 template<
typename _Fn>
1779 or_else(_Fn&& __f)
const
1781 static_assert(is_same_v<remove_cvref_t<invoke_result_t<_Fn>>, optional>,
1782 "the function passed to std::optional<T&>::or_else "
1783 "must return a std::optional<T&>");
1793 constexpr void reset() noexcept
1799 _Tp *_M_val =
nullptr;
1801 [[__gnu__::__always_inline__]]
1803 _M_fwd() const noexcept
1806 template<
typename _Up>
friend class optional;
1808 template<
typename _Up>
1811 __convert_ref_init_val(_Up&& __u)
1818 template<
typename _Fn,
typename _Value>
1820 optional(_Optional_func<_Fn> __f, _Value&& __v)
1828 template<
typename _Tp>
1829 using __optional_relop_t =
1832 template<
typename _Tp,
typename _Up>
1833 using __optional_eq_t = __optional_relop_t<
1837 template<
typename _Tp,
typename _Up>
1838 using __optional_ne_t = __optional_relop_t<
1842 template<
typename _Tp,
typename _Up>
1843 using __optional_lt_t = __optional_relop_t<
1847 template<
typename _Tp,
typename _Up>
1848 using __optional_gt_t = __optional_relop_t<
1852 template<
typename _Tp,
typename _Up>
1853 using __optional_le_t = __optional_relop_t<
1857 template<
typename _Tp,
typename _Up>
1858 using __optional_ge_t = __optional_relop_t<
1863 template<
typename _Tp,
typename _Up>
1865 operator==(
const optional<_Tp>& __lhs,
const optional<_Up>& __rhs)
1866 -> __optional_eq_t<_Tp, _Up>
1868 if (__lhs.has_value() != __rhs.has_value())
1870 if (!__lhs.has_value())
1872 return *__lhs == *__rhs;
1875 template<
typename _Tp,
typename _Up>
1877 operator!=(
const optional<_Tp>& __lhs,
const optional<_Up>& __rhs)
1878 -> __optional_ne_t<_Tp, _Up>
1880 if (__lhs.has_value() != __rhs.has_value())
1882 if (!__lhs.has_value())
1884 return *__lhs != *__rhs;
1887 template<
typename _Tp,
typename _Up>
1889 operator<(
const optional<_Tp>& __lhs,
const optional<_Up>& __rhs)
1890 -> __optional_lt_t<_Tp, _Up>
1892 if (!__rhs.has_value())
1894 if (!__lhs.has_value())
1896 return *__lhs < *__rhs;
1899 template<
typename _Tp,
typename _Up>
1901 operator>(
const optional<_Tp>& __lhs,
const optional<_Up>& __rhs)
1902 -> __optional_gt_t<_Tp, _Up>
1904 if (!__lhs.has_value())
1906 if (!__rhs.has_value())
1908 return *__lhs > *__rhs;
1911 template<
typename _Tp,
typename _Up>
1913 operator<=(
const optional<_Tp>& __lhs,
const optional<_Up>& __rhs)
1914 -> __optional_le_t<_Tp, _Up>
1916 if (!__lhs.has_value())
1918 if (!__rhs.has_value())
1920 return *__lhs <= *__rhs;
1923 template<
typename _Tp,
typename _Up>
1925 operator>=(
const optional<_Tp>& __lhs,
const optional<_Up>& __rhs)
1926 -> __optional_ge_t<_Tp, _Up>
1928 if (!__rhs.has_value())
1930 if (!__lhs.has_value())
1932 return *__lhs >= *__rhs;
1935#ifdef __cpp_lib_three_way_comparison
1936 template<
typename _Tp, three_way_comparable_with<_Tp> _Up>
1939 operator<=>(
const optional<_Tp>& __x,
const optional<_Up>& __y)
1941 return __x && __y ? *__x <=> *__y : bool(__x) <=> bool(__y);
1946 template<
typename _Tp>
1949 operator==(
const optional<_Tp>& __lhs, nullopt_t)
noexcept
1952#ifdef __cpp_lib_three_way_comparison
1953 template<
typename _Tp>
1955 constexpr strong_ordering
1956 operator<=>(
const optional<_Tp>& __x, nullopt_t)
noexcept
1957 {
return bool(__x) <=>
false; }
1959 template<
typename _Tp>
1961 operator==(nullopt_t,
const optional<_Tp>& __rhs)
noexcept
1964 template<
typename _Tp>
1966 operator!=(
const optional<_Tp>& __lhs, nullopt_t)
noexcept
1967 {
return static_cast<bool>(__lhs); }
1969 template<
typename _Tp>
1971 operator!=(nullopt_t,
const optional<_Tp>& __rhs)
noexcept
1972 {
return static_cast<bool>(__rhs); }
1974 template<
typename _Tp>
1976 operator<(
const optional<_Tp>& , nullopt_t)
noexcept
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>& __lhs, nullopt_t)
noexcept
1987 {
return static_cast<bool>(__lhs); }
1989 template<
typename _Tp>
1991 operator>(nullopt_t,
const optional<_Tp>& )
noexcept
1994 template<
typename _Tp>
1996 operator<=(
const optional<_Tp>& __lhs, nullopt_t)
noexcept
1999 template<
typename _Tp>
2001 operator<=(nullopt_t,
const optional<_Tp>& )
noexcept
2004 template<
typename _Tp>
2006 operator>=(
const optional<_Tp>& , nullopt_t)
noexcept
2009 template<
typename _Tp>
2011 operator>=(nullopt_t,
const optional<_Tp>& __rhs)
noexcept
2015#if __cpp_lib_concepts
2018# define _REQUIRES_NOT_OPTIONAL(T) requires (!__is_optional_v<T>)
2020# define _REQUIRES_NOT_OPTIONAL(T)
2024 template<
typename _Tp,
typename _Up>
2025 _REQUIRES_NOT_OPTIONAL(_Up)
2027 operator== [[nodiscard]] (
const optional<_Tp>& __lhs,
const _Up& __rhs)
2028 -> __optional_eq_t<_Tp, _Up>
2030 if (__lhs.has_value())
2031 return *__lhs == __rhs;
2035 template<
typename _Tp,
typename _Up>
2036 _REQUIRES_NOT_OPTIONAL(_Tp)
2038 operator== [[nodiscard]] (
const _Tp& __lhs,
const optional<_Up>& __rhs)
2039 -> __optional_eq_t<_Tp, _Up>
2041 if (__rhs.has_value())
2042 return __lhs == *__rhs;
2046 template<
typename _Tp,
typename _Up>
2047 _REQUIRES_NOT_OPTIONAL(_Up)
2049 operator!= [[nodiscard]] (
const optional<_Tp>& __lhs,
const _Up& __rhs)
2050 -> __optional_ne_t<_Tp, _Up>
2052 if (__lhs.has_value())
2053 return *__lhs != __rhs;
2057 template<
typename _Tp,
typename _Up>
2058 _REQUIRES_NOT_OPTIONAL(_Tp)
2060 operator!= [[nodiscard]] (
const _Tp& __lhs,
const optional<_Up>& __rhs)
2061 -> __optional_ne_t<_Tp, _Up>
2063 if (__rhs.has_value())
2064 return __lhs != *__rhs;
2068 template<
typename _Tp,
typename _Up>
2069 _REQUIRES_NOT_OPTIONAL(_Up)
2071 operator< [[nodiscard]] (
const optional<_Tp>& __lhs,
const _Up& __rhs)
2072 -> __optional_lt_t<_Tp, _Up>
2074 if (__lhs.has_value())
2075 return *__lhs < __rhs;
2079 template<
typename _Tp,
typename _Up>
2080 _REQUIRES_NOT_OPTIONAL(_Tp)
2082 operator< [[nodiscard]] (
const _Tp& __lhs,
const optional<_Up>& __rhs)
2083 -> __optional_lt_t<_Tp, _Up>
2085 if (__rhs.has_value())
2086 return __lhs < *__rhs;
2090 template<
typename _Tp,
typename _Up>
2091 _REQUIRES_NOT_OPTIONAL(_Up)
2093 operator> [[nodiscard]] (
const optional<_Tp>& __lhs,
const _Up& __rhs)
2094 -> __optional_gt_t<_Tp, _Up>
2096 if (__lhs.has_value())
2097 return *__lhs > __rhs;
2101 template<
typename _Tp,
typename _Up>
2102 _REQUIRES_NOT_OPTIONAL(_Tp)
2104 operator> [[nodiscard]] (
const _Tp& __lhs,
const optional<_Up>& __rhs)
2105 -> __optional_gt_t<_Tp, _Up>
2107 if (__rhs.has_value())
2108 return __lhs > *__rhs;
2112 template<
typename _Tp,
typename _Up>
2113 _REQUIRES_NOT_OPTIONAL(_Up)
2115 operator<= [[nodiscard]] (
const optional<_Tp>& __lhs,
const _Up& __rhs)
2116 -> __optional_le_t<_Tp, _Up>
2118 if (__lhs.has_value())
2119 return *__lhs <= __rhs;
2123 template<
typename _Tp,
typename _Up>
2124 _REQUIRES_NOT_OPTIONAL(_Tp)
2126 operator<= [[nodiscard]] (
const _Tp& __lhs,
const optional<_Up>& __rhs)
2127 -> __optional_le_t<_Tp, _Up>
2129 if (__rhs.has_value())
2130 return __lhs <= *__rhs;
2134 template<
typename _Tp,
typename _Up>
2135 _REQUIRES_NOT_OPTIONAL(_Up)
2137 operator>= [[nodiscard]] (
const optional<_Tp>& __lhs,
const _Up& __rhs)
2138 -> __optional_ge_t<_Tp, _Up>
2140 if (__lhs.has_value())
2141 return *__lhs >= __rhs;
2145 template<
typename _Tp,
typename _Up>
2146 _REQUIRES_NOT_OPTIONAL(_Tp)
2148 operator>= [[nodiscard]] (
const _Tp& __lhs,
const optional<_Up>& __rhs)
2149 -> __optional_ge_t<_Tp, _Up>
2151 if (__rhs.has_value())
2152 return __lhs >= *__rhs;
2156#ifdef __cpp_lib_three_way_comparison
2160 template<
typename _Tp>
2161 concept __is_derived_from_optional =
requires (
const _Tp& __t) {
2162 []<
typename _Up>(
const optional<_Up>&){ }(__t);
2165 template<
typename _Tp,
typename _Up>
2166 requires (!__is_derived_from_optional<_Up>)
2168 && three_way_comparable_with<_Tp, _Up>
2170 operator<=> [[nodiscard]] (
const optional<_Tp>& __x,
const _Up& __v)
2171 {
return bool(__x) ? *__x <=> __v : strong_ordering::less; }
2178 template<
typename _Tp>
2179 _GLIBCXX20_CONSTEXPR
2181 swap(optional<_Tp>& __lhs, optional<_Tp>& __rhs)
2182 noexcept(
noexcept(__lhs.swap(__rhs)))
2183 { __lhs.swap(__rhs); }
2185#if __cpp_lib_optional >= 202506L
2188 template<
typename _Tp>
2190 swap(optional<_Tp&>& __lhs, optional<_Tp&>& __rhs)
noexcept
2191 { __lhs.swap(__rhs); }
2196 template<
typename _Tp>
2197 enable_if_t<!(is_move_constructible_v<_Tp> && is_swappable_v<_Tp>)>
2198 swap(optional<_Tp>&, optional<_Tp>&) =
delete;
2200#if __cpp_lib_optional >= 202506L
2201 template<
int = 0,
typename _Tp>
2203 template<
typename _Tp>
2207 optional<decay_t<_Tp>>>
2208 make_optional(_Tp&& __t)
2209 noexcept(is_nothrow_constructible_v<optional<decay_t<_Tp>>, _Tp>)
2212 template<
typename _Tp,
typename... _Args>
2216 make_optional(_Args&&... __args)
2217 noexcept(is_nothrow_constructible_v<_Tp, _Args...>)
2220 template<
typename _Tp,
typename _Up,
typename... _Args>
2225 noexcept(is_nothrow_constructible_v<_Tp, initializer_list<_Up>&, _Args...>)
2230 template<
typename _Tp,
typename _Up = remove_const_t<_Tp>>
2231 struct __optional_hash
2232#if ! _GLIBCXX_INLINE_VERSION
2233 :
public __hash_empty_base<_Up>
2236#if __cplusplus < 202002L
2237 using result_type [[__deprecated__]] = size_t;
2238 using argument_type [[__deprecated__]] = optional<_Tp>;
2242 operator()(
const optional<_Tp>& __t)
const
2243 noexcept(
noexcept(hash<_Up>{}(*__t)))
2247 constexpr size_t __magic_disengaged_hash =
static_cast<size_t>(-3333);
2248 return __t ? hash<_Up>{}(*__t) : __magic_disengaged_hash;
2252 template<
typename _Tp>
2253 struct hash<optional<_Tp>>
2255 :
public __conditional_t<__is_hash_enabled_for<remove_const_t<_Tp>>,
2256 __optional_hash<_Tp>,
2257 __hash_not_enabled<_Tp>>
2260 template<
typename _Tp>
2266#if __cpp_deduction_guides >= 201606
2267 template <
typename _Tp> optional(_Tp) -> optional<_Tp>;
2270#ifdef __cpp_lib_optional_range_support
2271 template<
typename _Tp>
2272 inline constexpr bool
2275#if __cpp_lib_optional >= 202506L
2276 template<
typename _Tp>
2278 ranges::enable_borrowed_range<optional<_Tp&>> =
true;
2281 template<
typename _Tp>
2282 inline constexpr range_format
2283 format_kind<optional<_Tp>> = range_format::disabled;
2286#undef _GLIBCXX_USE_CONSTRAINTS_FOR_OPTIONAL
2288_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.
_Tp * end(valarray< _Tp > &__va) noexcept
Return an iterator pointing to one past the last element of the valarray.
_Tp * begin(valarray< _Tp > &__va) noexcept
Return an iterator pointing to the first element of the valarray.
constexpr nullopt_t nullopt
Tag to disengage optional objects.
ISO C++ entities toplevel namespace is std.
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)
Primary class template hash.
Base class for all library exceptions.
[concept.invocable], concept invocable