32#pragma GCC system_header
34#define __glibcxx_want_any
45namespace std _GLIBCXX_VISIBILITY(default)
47_GLIBCXX_BEGIN_NAMESPACE_VERSION
58 class bad_any_cast :
public bad_cast
61 virtual const char* what() const noexcept {
return "bad any_cast"; }
64 [[gnu::noreturn]]
inline void __throw_bad_any_cast()
86 constexpr _Storage() : _M_ptr{nullptr} {}
89 _Storage(
const _Storage&) =
delete;
90 _Storage& operator=(
const _Storage&) =
delete;
93 aligned_storage<
sizeof(_M_ptr),
alignof(
void*)>::type _M_buffer;
96 template<
typename _Tp,
typename _Safe = is_nothrow_move_constructible<_Tp>,
97 bool _Fits = (sizeof(_Tp) <= sizeof(_Storage))
98 && (alignof(_Tp) <= alignof(_Storage))>
99 using _Internal = std::
integral_constant<
bool, _Safe::value && _Fits>;
101 template<
typename _Tp>
102 struct _Manager_internal;
104 template<
typename _Tp>
105 struct _Manager_external;
107 template<
typename _Tp>
108 using _Manager = __conditional_t<_Internal<_Tp>::value,
109 _Manager_internal<_Tp>,
110 _Manager_external<_Tp>>;
112 template<
typename _Tp,
typename _VTp = decay_t<_Tp>>
113 using _Decay_if_not_any = enable_if_t<!is_same_v<_VTp, any>, _VTp>;
116 template <
typename _Tp,
typename... _Args,
117 typename _Mgr = _Manager<_Tp>>
118 void __do_emplace(_Args&&... __args)
121 _Mgr::_S_create(_M_storage, std::forward<_Args>(__args)...);
122 _M_manager = &_Mgr::_S_manage;
127 template <
typename _Tp,
typename _Up,
typename... _Args,
128 typename _Mgr = _Manager<_Tp>>
129 void __do_emplace(initializer_list<_Up> __il, _Args&&... __args)
132 _Mgr::_S_create(_M_storage, __il, std::forward<_Args>(__args)...);
133 _M_manager = &_Mgr::_S_manage;
136 template <
typename _Res,
typename _Tp,
typename... _Args>
137 using __any_constructible
138 = enable_if<__and_<is_copy_constructible<_Tp>,
139 is_constructible<_Tp, _Args...>>::value,
142 template <
typename _Tp,
typename... _Args>
143 using __any_constructible_t
144 =
typename __any_constructible<bool, _Tp, _Args...>::type;
146 template<
typename _VTp,
typename... _Args>
148 =
typename __any_constructible<_VTp&, _VTp, _Args...>::type;
154 constexpr any() noexcept : _M_manager(
nullptr) { }
157 any(
const any& __other)
159 if (!__other.has_value())
160 _M_manager =
nullptr;
165 __other._M_manager(_Op_clone, &__other, &__arg);
174 any(any&& __other)
noexcept
176 if (!__other.has_value())
177 _M_manager =
nullptr;
182 __other._M_manager(_Op_xfer, &__other, &__arg);
187 template <
typename _Tp,
typename _VTp = _Decay_if_not_any<_Tp>,
188 typename _Mgr = _Manager<_VTp>,
189 enable_if_t<is_copy_constructible_v<_VTp>
190 && !__is_in_place_type_v<_VTp>,
bool> = true>
192 : _M_manager(&_Mgr::_S_manage)
194 _Mgr::_S_create(_M_storage, std::forward<_Tp>(__value));
198 template <
typename _Tp,
typename... _Args,
typename _VTp = decay_t<_Tp>,
199 typename _Mgr = _Manager<_VTp>,
200 __any_constructible_t<_VTp, _Args&&...> =
false>
202 any(in_place_type_t<_Tp>, _Args&&... __args)
203 : _M_manager(&_Mgr::_S_manage)
205 _Mgr::_S_create(_M_storage, std::forward<_Args>(__args)...);
210 template <
typename _Tp,
typename _Up,
typename... _Args,
211 typename _VTp = decay_t<_Tp>,
typename _Mgr = _Manager<_VTp>,
212 __any_constructible_t<_VTp, initializer_list<_Up>&,
215 any(in_place_type_t<_Tp>, initializer_list<_Up> __il, _Args&&... __args)
216 : _M_manager(&_Mgr::_S_manage)
218 _Mgr::_S_create(_M_storage, __il, std::forward<_Args>(__args)...);
228 operator=(
const any& __rhs)
240 operator=(any&& __rhs)
noexcept
242 if (!__rhs.has_value())
244 else if (
this != &__rhs)
249 __rhs._M_manager(_Op_xfer, &__rhs, &__arg);
255 template<
typename _Tp>
256 enable_if_t<is_copy_constructible<_Decay_if_not_any<_Tp>>::value, any&>
257 operator=(_Tp&& __rhs)
259 *
this = any(std::forward<_Tp>(__rhs));
264 template <
typename _Tp,
typename... _Args>
265 __emplace_t<decay_t<_Tp>, _Args...>
266 emplace(_Args&&... __args)
268 using _VTp = decay_t<_Tp>;
269 __do_emplace<_VTp>(std::forward<_Args>(__args)...);
270 return *any::_Manager<_VTp>::_S_access(_M_storage);
275 template <
typename _Tp,
typename _Up,
typename... _Args>
276 __emplace_t<decay_t<_Tp>, initializer_list<_Up>&, _Args&&...>
277 emplace(initializer_list<_Up> __il, _Args&&... __args)
279 using _VTp = decay_t<_Tp>;
280 __do_emplace<_VTp, _Up>(__il, std::forward<_Args>(__args)...);
281 return *any::_Manager<_VTp>::_S_access(_M_storage);
287 void reset() noexcept
291 _M_manager(_Op_destroy,
this,
nullptr);
292 _M_manager =
nullptr;
297 void swap(any& __rhs)
noexcept
299 if (!has_value() && !__rhs.has_value())
302 if (has_value() && __rhs.has_value())
309 __arg._M_any = &__tmp;
310 __rhs._M_manager(_Op_xfer, &__rhs, &__arg);
311 __arg._M_any = &__rhs;
312 _M_manager(_Op_xfer,
this, &__arg);
314 __tmp._M_manager(_Op_xfer, &__tmp, &__arg);
318 any* __empty = !has_value() ? this : &__rhs;
319 any* __full = !has_value() ? &__rhs :
this;
321 __arg._M_any = __empty;
322 __full->_M_manager(_Op_xfer, __full, &__arg);
329 bool has_value() const noexcept {
return _M_manager !=
nullptr; }
333 const type_info& type() const noexcept
338 _M_manager(_Op_get_type_info,
this, &__arg);
339 return *__arg._M_typeinfo;
344 template<
typename _Tp>
345 static constexpr bool __is_valid_cast()
346 {
return __or_<is_reference<_Tp>, is_copy_constructible<_Tp>>::value; }
351 _Op_access, _Op_get_type_info, _Op_clone, _Op_destroy, _Op_xfer
361 void (*_M_manager)(_Op,
const any*, _Arg*);
365 template<
typename _Tp>
366 friend void* __any_caster(
const any* __any);
370 template<
typename _Tp>
371 struct _Manager_internal
374 _S_manage(_Op __which,
const any* __anyp, _Arg* __arg);
376 template<
typename _Up>
378 _S_create(_Storage& __storage, _Up&& __value)
380 void* __addr = &__storage._M_buffer;
381 ::new (__addr) _Tp(std::forward<_Up>(__value));
384 template<
typename... _Args>
386 _S_create(_Storage& __storage, _Args&&... __args)
388 void* __addr = &__storage._M_buffer;
389 ::new (__addr) _Tp(std::forward<_Args>(__args)...);
393 _S_access(
const _Storage& __storage)
396 const void* __addr = &__storage._M_buffer;
397 return static_cast<_Tp*
>(
const_cast<void*
>(__addr));
402 template<
typename _Tp>
403 struct _Manager_external
406 _S_manage(_Op __which,
const any* __anyp, _Arg* __arg);
408 template<
typename _Up>
410 _S_create(_Storage& __storage, _Up&& __value)
412 __storage._M_ptr =
new _Tp(std::forward<_Up>(__value));
414 template<
typename... _Args>
416 _S_create(_Storage& __storage, _Args&&... __args)
418 __storage._M_ptr =
new _Tp(std::forward<_Args>(__args)...);
421 _S_access(
const _Storage& __storage)
424 return static_cast<_Tp*
>(__storage._M_ptr);
430 inline void swap(any& __x, any& __y)
noexcept { __x.swap(__y); }
433 template <
typename _Tp,
typename... _Args>
435 enable_if_t<is_constructible_v<any, in_place_type_t<_Tp>, _Args...>, any>
436 make_any(_Args&&... __args)
438 return any(in_place_type<_Tp>, std::forward<_Args>(__args)...);
442 template <
typename _Tp,
typename _Up,
typename... _Args>
444 enable_if_t<is_constructible_v<any, in_place_type_t<_Tp>,
445 initializer_list<_Up>&, _Args...>, any>
446 make_any(initializer_list<_Up> __il, _Args&&... __args)
448 return any(in_place_type<_Tp>, __il, std::forward<_Args>(__args)...);
461 template<
typename _ValueType>
462 inline _ValueType
any_cast(
const any& __any)
464 using _Up = __remove_cvref_t<_ValueType>;
465 static_assert(any::__is_valid_cast<_ValueType>(),
466 "Template argument must be a reference or CopyConstructible type");
467 static_assert(is_constructible_v<_ValueType, const _Up&>,
468 "Template argument must be constructible from a const value.");
469 auto __p = any_cast<_Up>(&__any);
471 return static_cast<_ValueType
>(*__p);
472 __throw_bad_any_cast();
487 template<
typename _ValueType>
488 inline _ValueType
any_cast(any& __any)
490 using _Up = __remove_cvref_t<_ValueType>;
491 static_assert(any::__is_valid_cast<_ValueType>(),
492 "Template argument must be a reference or CopyConstructible type");
493 static_assert(is_constructible_v<_ValueType, _Up&>,
494 "Template argument must be constructible from an lvalue.");
495 auto __p = any_cast<_Up>(&__any);
497 return static_cast<_ValueType
>(*__p);
498 __throw_bad_any_cast();
501 template<
typename _ValueType>
502 inline _ValueType
any_cast(any&& __any)
504 using _Up = __remove_cvref_t<_ValueType>;
505 static_assert(any::__is_valid_cast<_ValueType>(),
506 "Template argument must be a reference or CopyConstructible type");
507 static_assert(is_constructible_v<_ValueType, _Up>,
508 "Template argument must be constructible from an rvalue.");
509 auto __p = any_cast<_Up>(&__any);
511 return static_cast<_ValueType
>(
std::move(*__p));
512 __throw_bad_any_cast();
517 template<
typename _Tp>
518 void* __any_caster(
const any* __any)
522 using _Up = remove_cv_t<_Tp>;
525 if constexpr (!is_same_v<decay_t<_Up>, _Up>)
528 else if constexpr (!is_copy_constructible_v<_Up>)
531 else if (__any->_M_manager == &any::_Manager<_Up>::_S_manage
533 || __any->type() ==
typeid(_Tp)
537 return any::_Manager<_Up>::_S_access(__any->_M_storage);
554 template<
typename _ValueType>
555 inline const _ValueType*
any_cast(
const any* __any)
noexcept
559 static_assert(!is_void_v<_ValueType>);
563 if constexpr (is_object_v<_ValueType>)
565 return static_cast<_ValueType*
>(__any_caster<_ValueType>(__any));
569 template<
typename _ValueType>
570 inline _ValueType*
any_cast(any* __any)
noexcept
572 static_assert(!is_void_v<_ValueType>);
574 if constexpr (is_object_v<_ValueType>)
576 return static_cast<_ValueType*
>(__any_caster<_ValueType>(__any));
581 template<
typename _Tp>
583 any::_Manager_internal<_Tp>::
584 _S_manage(_Op __which,
const any* __any, _Arg* __arg)
587 auto __ptr =
reinterpret_cast<const _Tp*
>(&__any->_M_storage._M_buffer);
591 __arg->_M_obj =
const_cast<_Tp*
>(__ptr);
593 case _Op_get_type_info:
595 __arg->_M_typeinfo = &
typeid(_Tp);
599 ::new(&__arg->_M_any->_M_storage._M_buffer) _Tp(*__ptr);
600 __arg->_M_any->_M_manager = __any->_M_manager;
606 ::new(&__arg->_M_any->_M_storage._M_buffer) _Tp
607 (
std::
move(*const_cast<_Tp*>(__ptr)));
609 __arg->_M_any->_M_manager = __any->_M_manager;
610 const_cast<any*>(__any)->_M_manager =
nullptr;
615 template<typename _Tp>
617 any::_Manager_external<_Tp>::
618 _S_manage(_Op __which, const any* __any, _Arg* __arg)
621 auto __ptr =
static_cast<const _Tp*
>(__any->_M_storage._M_ptr);
625 __arg->_M_obj =
const_cast<_Tp*
>(__ptr);
627 case _Op_get_type_info:
629 __arg->_M_typeinfo = &
typeid(_Tp);
633 __arg->_M_any->_M_storage._M_ptr =
new _Tp(*__ptr);
634 __arg->_M_any->_M_manager = __any->_M_manager;
640 __arg->_M_any->_M_storage._M_ptr = __any->_M_storage._M_ptr;
641 __arg->_M_any->_M_manager = __any->_M_manager;
642 const_cast<any*
>(__any)->_M_manager =
nullptr;
649 namespace __detail::__variant
651 template<
typename>
struct _Never_valueless_alt;
656 struct _Never_valueless_alt<
std::any>
661_GLIBCXX_END_NAMESPACE_VERSION
__bool_constant< true > true_type
The type used as a compile-time boolean with true value.
constexpr std::remove_reference< _Tp >::type && move(_Tp &&__t) noexcept
Convert a value to an rvalue.
_ValueType any_cast(const any &__any)
Access the contained object.
ISO C++ entities toplevel namespace is std.