1 // C++11 <type_traits> -*- C++ -*-
3 // Copyright (C) 2007-2015 Free Software Foundation, Inc.
5 // This file is part of the GNU ISO C++ Library. This library is free
6 // software; you can redistribute it and/or modify it under the
7 // terms of the GNU General Public License as published by the
8 // Free Software Foundation; either version 3, or (at your option)
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 // GNU General Public License for more details.
16 // Under Section 7 of GPL version 3, you are granted additional
17 // permissions described in the GCC Runtime Library Exception, version
18 // 3.1, as published by the Free Software Foundation.
20 // You should have received a copy of the GNU General Public License and
21 // a copy of the GCC Runtime Library Exception along with this program;
22 // see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
23 // <http://www.gnu.org/licenses/>.
25 /** @file include/type_traits
26 * This is a Standard C++ Library header.
29 #ifndef _GLIBCXX_TYPE_TRAITS
30 #define _GLIBCXX_TYPE_TRAITS 1
32 #pragma GCC system_header
34 #if __cplusplus < 201103L
35 # include <bits/c++0x_warning.h>
38 #include <bits/c++config.h>
40 #ifdef _GLIBCXX_USE_C99_STDINT_TR1
41 # if defined (__UINT_LEAST16_TYPE__) && defined(__UINT_LEAST32_TYPE__)
44 typedef __UINT_LEAST16_TYPE__ uint_least16_t;
45 typedef __UINT_LEAST32_TYPE__ uint_least32_t;
52 namespace std _GLIBCXX_VISIBILITY(default)
54 _GLIBCXX_BEGIN_NAMESPACE_VERSION
57 * @defgroup metaprogramming Metaprogramming
60 * Template utilities for compile-time introspection and modification,
61 * including type classification traits, type property inspection traits
62 * and type transformation traits.
68 template<typename _Tp, _Tp __v>
69 struct integral_constant
71 static constexpr _Tp value = __v;
72 typedef _Tp value_type;
73 typedef integral_constant<_Tp, __v> type;
74 constexpr operator value_type() const { return value; }
75 #if __cplusplus > 201103L
77 #define __cpp_lib_integral_constant_callable 201304
79 constexpr value_type operator()() const { return value; }
83 template<typename _Tp, _Tp __v>
84 constexpr _Tp integral_constant<_Tp, __v>::value;
86 /// The type used as a compile-time boolean with true value.
87 typedef integral_constant<bool, true> true_type;
89 /// The type used as a compile-time boolean with false value.
90 typedef integral_constant<bool, false> false_type;
93 using __bool_constant = integral_constant<bool, __v>;
95 #if __cplusplus > 201402L
96 # define __cpp_lib_bool_constant 201505
98 using bool_constant = integral_constant<bool, __v>;
101 // Meta programming helper types.
103 template<bool, typename, typename>
106 template<typename...>
114 template<typename _B1>
119 template<typename _B1, typename _B2>
120 struct __or_<_B1, _B2>
121 : public conditional<_B1::value, _B1, _B2>::type
124 template<typename _B1, typename _B2, typename _B3, typename... _Bn>
125 struct __or_<_B1, _B2, _B3, _Bn...>
126 : public conditional<_B1::value, _B1, __or_<_B2, _B3, _Bn...>>::type
129 template<typename...>
137 template<typename _B1>
142 template<typename _B1, typename _B2>
143 struct __and_<_B1, _B2>
144 : public conditional<_B1::value, _B2, _B1>::type
147 template<typename _B1, typename _B2, typename _B3, typename... _Bn>
148 struct __and_<_B1, _B2, _B3, _Bn...>
149 : public conditional<_B1::value, __and_<_B2, _B3, _Bn...>, _B1>::type
152 template<typename _Pp>
154 : public integral_constant<bool, !_Pp::value>
157 #if __cplusplus > 201402L
159 #define __cpp_lib_logical_traits 201511
161 template<typename... _Bn>
166 template<typename... _Bn>
171 template<typename _Pp>
177 // For several sfinae-friendly trait implementations we transport both the
178 // result information (as the member type) and the failure information (no
179 // member type). This is very similar to std::enable_if, but we cannot use
180 // them, because we need to derive from them as an implementation detail.
182 template<typename _Tp>
183 struct __success_type
184 { typedef _Tp type; };
186 struct __failure_type
189 // Primary type categories.
195 struct __is_void_helper
196 : public false_type { };
199 struct __is_void_helper<void>
200 : public true_type { };
203 template<typename _Tp>
205 : public __is_void_helper<typename remove_cv<_Tp>::type>::type
209 struct __is_integral_helper
210 : public false_type { };
213 struct __is_integral_helper<bool>
214 : public true_type { };
217 struct __is_integral_helper<char>
218 : public true_type { };
221 struct __is_integral_helper<signed char>
222 : public true_type { };
225 struct __is_integral_helper<unsigned char>
226 : public true_type { };
228 #ifdef _GLIBCXX_USE_WCHAR_T
230 struct __is_integral_helper<wchar_t>
231 : public true_type { };
235 struct __is_integral_helper<char16_t>
236 : public true_type { };
239 struct __is_integral_helper<char32_t>
240 : public true_type { };
243 struct __is_integral_helper<short>
244 : public true_type { };
247 struct __is_integral_helper<unsigned short>
248 : public true_type { };
251 struct __is_integral_helper<int>
252 : public true_type { };
255 struct __is_integral_helper<unsigned int>
256 : public true_type { };
259 struct __is_integral_helper<long>
260 : public true_type { };
263 struct __is_integral_helper<unsigned long>
264 : public true_type { };
267 struct __is_integral_helper<long long>
268 : public true_type { };
271 struct __is_integral_helper<unsigned long long>
272 : public true_type { };
274 // Conditionalizing on __STRICT_ANSI__ here will break any port that
275 // uses one of these types for size_t.
276 #if defined(__GLIBCXX_TYPE_INT_N_0)
278 struct __is_integral_helper<__GLIBCXX_TYPE_INT_N_0>
279 : public true_type { };
282 struct __is_integral_helper<unsigned __GLIBCXX_TYPE_INT_N_0>
283 : public true_type { };
285 #if defined(__GLIBCXX_TYPE_INT_N_1)
287 struct __is_integral_helper<__GLIBCXX_TYPE_INT_N_1>
288 : public true_type { };
291 struct __is_integral_helper<unsigned __GLIBCXX_TYPE_INT_N_1>
292 : public true_type { };
294 #if defined(__GLIBCXX_TYPE_INT_N_2)
296 struct __is_integral_helper<__GLIBCXX_TYPE_INT_N_2>
297 : public true_type { };
300 struct __is_integral_helper<unsigned __GLIBCXX_TYPE_INT_N_2>
301 : public true_type { };
303 #if defined(__GLIBCXX_TYPE_INT_N_3)
305 struct __is_integral_helper<__GLIBCXX_TYPE_INT_N_3>
306 : public true_type { };
309 struct __is_integral_helper<unsigned __GLIBCXX_TYPE_INT_N_3>
310 : public true_type { };
314 template<typename _Tp>
316 : public __is_integral_helper<typename remove_cv<_Tp>::type>::type
320 struct __is_floating_point_helper
321 : public false_type { };
324 struct __is_floating_point_helper<float>
325 : public true_type { };
328 struct __is_floating_point_helper<double>
329 : public true_type { };
332 struct __is_floating_point_helper<long double>
333 : public true_type { };
335 #if !defined(__STRICT_ANSI__) && defined(_GLIBCXX_USE_FLOAT128)
337 struct __is_floating_point_helper<__float128>
338 : public true_type { };
341 /// is_floating_point
342 template<typename _Tp>
343 struct is_floating_point
344 : public __is_floating_point_helper<typename remove_cv<_Tp>::type>::type
350 : public false_type { };
352 template<typename _Tp, std::size_t _Size>
353 struct is_array<_Tp[_Size]>
354 : public true_type { };
356 template<typename _Tp>
357 struct is_array<_Tp[]>
358 : public true_type { };
361 struct __is_pointer_helper
362 : public false_type { };
364 template<typename _Tp>
365 struct __is_pointer_helper<_Tp*>
366 : public true_type { };
369 template<typename _Tp>
371 : public __is_pointer_helper<typename remove_cv<_Tp>::type>::type
374 /// is_lvalue_reference
376 struct is_lvalue_reference
377 : public false_type { };
379 template<typename _Tp>
380 struct is_lvalue_reference<_Tp&>
381 : public true_type { };
383 /// is_rvalue_reference
385 struct is_rvalue_reference
386 : public false_type { };
388 template<typename _Tp>
389 struct is_rvalue_reference<_Tp&&>
390 : public true_type { };
396 struct __is_member_object_pointer_helper
397 : public false_type { };
399 template<typename _Tp, typename _Cp>
400 struct __is_member_object_pointer_helper<_Tp _Cp::*>
401 : public integral_constant<bool, !is_function<_Tp>::value> { };
403 /// is_member_object_pointer
404 template<typename _Tp>
405 struct is_member_object_pointer
406 : public __is_member_object_pointer_helper<
407 typename remove_cv<_Tp>::type>::type
411 struct __is_member_function_pointer_helper
412 : public false_type { };
414 template<typename _Tp, typename _Cp>
415 struct __is_member_function_pointer_helper<_Tp _Cp::*>
416 : public integral_constant<bool, is_function<_Tp>::value> { };
418 /// is_member_function_pointer
419 template<typename _Tp>
420 struct is_member_function_pointer
421 : public __is_member_function_pointer_helper<
422 typename remove_cv<_Tp>::type>::type
426 template<typename _Tp>
428 : public integral_constant<bool, __is_enum(_Tp)>
432 template<typename _Tp>
434 : public integral_constant<bool, __is_union(_Tp)>
438 template<typename _Tp>
440 : public integral_constant<bool, __is_class(_Tp)>
446 : public false_type { };
448 template<typename _Res, typename... _ArgTypes>
449 struct is_function<_Res(_ArgTypes...)>
450 : public true_type { };
452 template<typename _Res, typename... _ArgTypes>
453 struct is_function<_Res(_ArgTypes...) &>
454 : public true_type { };
456 template<typename _Res, typename... _ArgTypes>
457 struct is_function<_Res(_ArgTypes...) &&>
458 : public true_type { };
460 template<typename _Res, typename... _ArgTypes>
461 struct is_function<_Res(_ArgTypes......)>
462 : public true_type { };
464 template<typename _Res, typename... _ArgTypes>
465 struct is_function<_Res(_ArgTypes......) &>
466 : public true_type { };
468 template<typename _Res, typename... _ArgTypes>
469 struct is_function<_Res(_ArgTypes......) &&>
470 : public true_type { };
472 template<typename _Res, typename... _ArgTypes>
473 struct is_function<_Res(_ArgTypes...) const>
474 : public true_type { };
476 template<typename _Res, typename... _ArgTypes>
477 struct is_function<_Res(_ArgTypes...) const &>
478 : public true_type { };
480 template<typename _Res, typename... _ArgTypes>
481 struct is_function<_Res(_ArgTypes...) const &&>
482 : public true_type { };
484 template<typename _Res, typename... _ArgTypes>
485 struct is_function<_Res(_ArgTypes......) const>
486 : public true_type { };
488 template<typename _Res, typename... _ArgTypes>
489 struct is_function<_Res(_ArgTypes......) const &>
490 : public true_type { };
492 template<typename _Res, typename... _ArgTypes>
493 struct is_function<_Res(_ArgTypes......) const &&>
494 : public true_type { };
496 template<typename _Res, typename... _ArgTypes>
497 struct is_function<_Res(_ArgTypes...) volatile>
498 : public true_type { };
500 template<typename _Res, typename... _ArgTypes>
501 struct is_function<_Res(_ArgTypes...) volatile &>
502 : public true_type { };
504 template<typename _Res, typename... _ArgTypes>
505 struct is_function<_Res(_ArgTypes...) volatile &&>
506 : public true_type { };
508 template<typename _Res, typename... _ArgTypes>
509 struct is_function<_Res(_ArgTypes......) volatile>
510 : public true_type { };
512 template<typename _Res, typename... _ArgTypes>
513 struct is_function<_Res(_ArgTypes......) volatile &>
514 : public true_type { };
516 template<typename _Res, typename... _ArgTypes>
517 struct is_function<_Res(_ArgTypes......) volatile &&>
518 : public true_type { };
520 template<typename _Res, typename... _ArgTypes>
521 struct is_function<_Res(_ArgTypes...) const volatile>
522 : public true_type { };
524 template<typename _Res, typename... _ArgTypes>
525 struct is_function<_Res(_ArgTypes...) const volatile &>
526 : public true_type { };
528 template<typename _Res, typename... _ArgTypes>
529 struct is_function<_Res(_ArgTypes...) const volatile &&>
530 : public true_type { };
532 template<typename _Res, typename... _ArgTypes>
533 struct is_function<_Res(_ArgTypes......) const volatile>
534 : public true_type { };
536 template<typename _Res, typename... _ArgTypes>
537 struct is_function<_Res(_ArgTypes......) const volatile &>
538 : public true_type { };
540 template<typename _Res, typename... _ArgTypes>
541 struct is_function<_Res(_ArgTypes......) const volatile &&>
542 : public true_type { };
544 #define __cpp_lib_is_null_pointer 201309
547 struct __is_null_pointer_helper
548 : public false_type { };
551 struct __is_null_pointer_helper<std::nullptr_t>
552 : public true_type { };
554 /// is_null_pointer (LWG 2247).
555 template<typename _Tp>
556 struct is_null_pointer
557 : public __is_null_pointer_helper<typename remove_cv<_Tp>::type>::type
560 /// __is_nullptr_t (extension).
561 template<typename _Tp>
562 struct __is_nullptr_t
563 : public is_null_pointer<_Tp>
566 // Composite type categories.
569 template<typename _Tp>
571 : public __or_<is_lvalue_reference<_Tp>,
572 is_rvalue_reference<_Tp>>::type
576 template<typename _Tp>
578 : public __or_<is_integral<_Tp>, is_floating_point<_Tp>>::type
582 template<typename _Tp>
583 struct is_fundamental
584 : public __or_<is_arithmetic<_Tp>, is_void<_Tp>,
585 is_null_pointer<_Tp>>::type
589 template<typename _Tp>
591 : public __not_<__or_<is_function<_Tp>, is_reference<_Tp>,
596 struct is_member_pointer;
599 template<typename _Tp>
601 : public __or_<is_arithmetic<_Tp>, is_enum<_Tp>, is_pointer<_Tp>,
602 is_member_pointer<_Tp>, is_null_pointer<_Tp>>::type
606 template<typename _Tp>
608 : public integral_constant<bool, !is_fundamental<_Tp>::value> { };
610 template<typename _Tp>
611 struct __is_member_pointer_helper
612 : public false_type { };
614 template<typename _Tp, typename _Cp>
615 struct __is_member_pointer_helper<_Tp _Cp::*>
616 : public true_type { };
618 /// is_member_pointer
619 template<typename _Tp>
620 struct is_member_pointer
621 : public __is_member_pointer_helper<typename remove_cv<_Tp>::type>::type
624 // Utility to detect referenceable types ([defns.referenceable]).
626 template<typename _Tp>
627 struct __is_referenceable
628 : public __or_<is_object<_Tp>, is_reference<_Tp>>::type
631 template<typename _Res, typename... _Args>
632 struct __is_referenceable<_Res(_Args...)>
636 template<typename _Res, typename... _Args>
637 struct __is_referenceable<_Res(_Args......)>
646 : public false_type { };
648 template<typename _Tp>
649 struct is_const<_Tp const>
650 : public true_type { };
655 : public false_type { };
657 template<typename _Tp>
658 struct is_volatile<_Tp volatile>
659 : public true_type { };
662 template<typename _Tp>
664 : public integral_constant<bool, __is_trivial(_Tp)>
667 // is_trivially_copyable
668 template<typename _Tp>
669 struct is_trivially_copyable
670 : public integral_constant<bool, __is_trivially_copyable(_Tp)>
673 /// is_standard_layout
674 template<typename _Tp>
675 struct is_standard_layout
676 : public integral_constant<bool, __is_standard_layout(_Tp)>
680 // Could use is_standard_layout && is_trivial instead of the builtin.
681 template<typename _Tp>
683 : public integral_constant<bool, __is_pod(_Tp)>
687 template<typename _Tp>
688 struct is_literal_type
689 : public integral_constant<bool, __is_literal_type(_Tp)>
693 template<typename _Tp>
695 : public integral_constant<bool, __is_empty(_Tp)>
699 template<typename _Tp>
700 struct is_polymorphic
701 : public integral_constant<bool, __is_polymorphic(_Tp)>
704 #if __cplusplus >= 201402L
705 #define __cpp_lib_is_final 201402L
707 template<typename _Tp>
709 : public integral_constant<bool, __is_final(_Tp)>
714 template<typename _Tp>
716 : public integral_constant<bool, __is_abstract(_Tp)>
719 template<typename _Tp,
720 bool = is_arithmetic<_Tp>::value>
721 struct __is_signed_helper
722 : public false_type { };
724 template<typename _Tp>
725 struct __is_signed_helper<_Tp, true>
726 : public integral_constant<bool, _Tp(-1) < _Tp(0)>
730 template<typename _Tp>
732 : public __is_signed_helper<_Tp>::type
736 template<typename _Tp>
738 : public __and_<is_arithmetic<_Tp>, __not_<is_signed<_Tp>>>
742 // Destructible and constructible type properties.
745 struct add_rvalue_reference;
748 * @brief Utility to simplify expressions used in unevaluated operands
751 template<typename _Tp>
752 typename add_rvalue_reference<_Tp>::type declval() noexcept;
754 template<typename, unsigned = 0>
758 struct remove_all_extents;
760 template<typename _Tp>
761 struct __is_array_known_bounds
762 : public integral_constant<bool, (extent<_Tp>::value > 0)>
765 template<typename _Tp>
766 struct __is_array_unknown_bounds
767 : public __and_<is_array<_Tp>, __not_<extent<_Tp>>>
770 // In N3290 is_destructible does not say anything about function
771 // types and abstract types, see LWG 2049. This implementation
772 // describes function types as non-destructible and all complete
773 // object types as destructible, iff the explicit destructor
774 // call expression is wellformed.
775 struct __do_is_destructible_impl
777 template<typename _Tp, typename = decltype(declval<_Tp&>().~_Tp())>
778 static true_type __test(int);
781 static false_type __test(...);
784 template<typename _Tp>
785 struct __is_destructible_impl
786 : public __do_is_destructible_impl
788 typedef decltype(__test<_Tp>(0)) type;
791 template<typename _Tp,
792 bool = __or_<is_void<_Tp>,
793 __is_array_unknown_bounds<_Tp>,
794 is_function<_Tp>>::value,
795 bool = __or_<is_reference<_Tp>, is_scalar<_Tp>>::value>
796 struct __is_destructible_safe;
798 template<typename _Tp>
799 struct __is_destructible_safe<_Tp, false, false>
800 : public __is_destructible_impl<typename
801 remove_all_extents<_Tp>::type>::type
804 template<typename _Tp>
805 struct __is_destructible_safe<_Tp, true, false>
806 : public false_type { };
808 template<typename _Tp>
809 struct __is_destructible_safe<_Tp, false, true>
810 : public true_type { };
813 template<typename _Tp>
814 struct is_destructible
815 : public __is_destructible_safe<_Tp>::type
818 // is_nothrow_destructible requires that is_destructible is
819 // satisfied as well. We realize that by mimicing the
820 // implementation of is_destructible but refer to noexcept(expr)
821 // instead of decltype(expr).
822 struct __do_is_nt_destructible_impl
824 template<typename _Tp>
825 static integral_constant<bool, noexcept(declval<_Tp&>().~_Tp())>
829 static false_type __test(...);
832 template<typename _Tp>
833 struct __is_nt_destructible_impl
834 : public __do_is_nt_destructible_impl
836 typedef decltype(__test<_Tp>(0)) type;
839 template<typename _Tp,
840 bool = __or_<is_void<_Tp>,
841 __is_array_unknown_bounds<_Tp>,
842 is_function<_Tp>>::value,
843 bool = __or_<is_reference<_Tp>, is_scalar<_Tp>>::value>
844 struct __is_nt_destructible_safe;
846 template<typename _Tp>
847 struct __is_nt_destructible_safe<_Tp, false, false>
848 : public __is_nt_destructible_impl<typename
849 remove_all_extents<_Tp>::type>::type
852 template<typename _Tp>
853 struct __is_nt_destructible_safe<_Tp, true, false>
854 : public false_type { };
856 template<typename _Tp>
857 struct __is_nt_destructible_safe<_Tp, false, true>
858 : public true_type { };
860 /// is_nothrow_destructible
861 template<typename _Tp>
862 struct is_nothrow_destructible
863 : public __is_nt_destructible_safe<_Tp>::type
866 struct __do_is_default_constructible_impl
868 template<typename _Tp, typename = decltype(_Tp())>
869 static true_type __test(int);
872 static false_type __test(...);
875 template<typename _Tp>
876 struct __is_default_constructible_impl
877 : public __do_is_default_constructible_impl
879 typedef decltype(__test<_Tp>(0)) type;
882 template<typename _Tp>
883 struct __is_default_constructible_atom
884 : public __and_<__not_<is_void<_Tp>>,
885 __is_default_constructible_impl<_Tp>>
888 template<typename _Tp, bool = is_array<_Tp>::value>
889 struct __is_default_constructible_safe;
891 // The following technique is a workaround for a current core language
892 // restriction, which does not allow for array types to occur in
893 // functional casts of the form T(). Complete arrays can be default-
894 // constructed, if the element type is default-constructible, but
895 // arrays with unknown bounds are not.
896 template<typename _Tp>
897 struct __is_default_constructible_safe<_Tp, true>
898 : public __and_<__is_array_known_bounds<_Tp>,
899 __is_default_constructible_atom<typename
900 remove_all_extents<_Tp>::type>>
903 template<typename _Tp>
904 struct __is_default_constructible_safe<_Tp, false>
905 : public __is_default_constructible_atom<_Tp>::type
908 /// is_default_constructible
909 template<typename _Tp>
910 struct is_default_constructible
911 : public __is_default_constructible_safe<_Tp>::type
915 // Implementation of is_constructible.
917 // The hardest part of this trait is the binary direct-initialization
918 // case, because we hit into a functional cast of the form T(arg).
919 // This implementation uses different strategies depending on the
920 // target type to reduce the test overhead as much as possible:
922 // a) For a reference target type, we use a static_cast expression
923 // modulo its extra cases.
925 // b) For a non-reference target type we use a ::new expression.
926 struct __do_is_static_castable_impl
928 template<typename _From, typename _To, typename
929 = decltype(static_cast<_To>(declval<_From>()))>
930 static true_type __test(int);
932 template<typename, typename>
933 static false_type __test(...);
936 template<typename _From, typename _To>
937 struct __is_static_castable_impl
938 : public __do_is_static_castable_impl
940 typedef decltype(__test<_From, _To>(0)) type;
943 template<typename _From, typename _To>
944 struct __is_static_castable_safe
945 : public __is_static_castable_impl<_From, _To>::type
948 // __is_static_castable
949 template<typename _From, typename _To>
950 struct __is_static_castable
951 : public integral_constant<bool, (__is_static_castable_safe<
955 // Implementation for non-reference types. To meet the proper
956 // variable definition semantics, we also need to test for
957 // is_destructible in this case.
958 // This form should be simplified by a single expression:
959 // ::delete ::new _Tp(declval<_Arg>()), see c++/51222.
960 struct __do_is_direct_constructible_impl
962 template<typename _Tp, typename _Arg, typename
963 = decltype(::new _Tp(declval<_Arg>()))>
964 static true_type __test(int);
966 template<typename, typename>
967 static false_type __test(...);
970 template<typename _Tp, typename _Arg>
971 struct __is_direct_constructible_impl
972 : public __do_is_direct_constructible_impl
974 typedef decltype(__test<_Tp, _Arg>(0)) type;
977 template<typename _Tp, typename _Arg>
978 struct __is_direct_constructible_new_safe
979 : public __and_<is_destructible<_Tp>,
980 __is_direct_constructible_impl<_Tp, _Arg>>
983 template<typename, typename>
986 template<typename, typename>
990 struct remove_reference;
992 template<typename _From, typename _To, bool
993 = __not_<__or_<is_void<_From>,
994 is_function<_From>>>::value>
995 struct __is_base_to_derived_ref;
997 // Detect whether we have a downcast situation during
998 // reference binding.
999 template<typename _From, typename _To>
1000 struct __is_base_to_derived_ref<_From, _To, true>
1002 typedef typename remove_cv<typename remove_reference<_From
1003 >::type>::type __src_t;
1004 typedef typename remove_cv<typename remove_reference<_To
1005 >::type>::type __dst_t;
1006 typedef __and_<__not_<is_same<__src_t, __dst_t>>,
1007 is_base_of<__src_t, __dst_t>> type;
1008 static constexpr bool value = type::value;
1011 template<typename _From, typename _To>
1012 struct __is_base_to_derived_ref<_From, _To, false>
1016 template<typename _From, typename _To, bool
1017 = __and_<is_lvalue_reference<_From>,
1018 is_rvalue_reference<_To>>::value>
1019 struct __is_lvalue_to_rvalue_ref;
1021 // Detect whether we have an lvalue of non-function type
1022 // bound to a reference-compatible rvalue-reference.
1023 template<typename _From, typename _To>
1024 struct __is_lvalue_to_rvalue_ref<_From, _To, true>
1026 typedef typename remove_cv<typename remove_reference<
1027 _From>::type>::type __src_t;
1028 typedef typename remove_cv<typename remove_reference<
1029 _To>::type>::type __dst_t;
1030 typedef __and_<__not_<is_function<__src_t>>,
1031 __or_<is_same<__src_t, __dst_t>,
1032 is_base_of<__dst_t, __src_t>>> type;
1033 static constexpr bool value = type::value;
1036 template<typename _From, typename _To>
1037 struct __is_lvalue_to_rvalue_ref<_From, _To, false>
1041 // Here we handle direct-initialization to a reference type as
1042 // equivalent to a static_cast modulo overshooting conversions.
1043 // These are restricted to the following conversions:
1044 // a) A base class value to a derived class reference
1045 // b) An lvalue to an rvalue-reference of reference-compatible
1046 // types that are not functions
1047 template<typename _Tp, typename _Arg>
1048 struct __is_direct_constructible_ref_cast
1049 : public __and_<__is_static_castable<_Arg, _Tp>,
1050 __not_<__or_<__is_base_to_derived_ref<_Arg, _Tp>,
1051 __is_lvalue_to_rvalue_ref<_Arg, _Tp>
1055 template<typename _Tp, typename _Arg>
1056 struct __is_direct_constructible_new
1057 : public conditional<is_reference<_Tp>::value,
1058 __is_direct_constructible_ref_cast<_Tp, _Arg>,
1059 __is_direct_constructible_new_safe<_Tp, _Arg>
1063 template<typename _Tp, typename _Arg>
1064 struct __is_direct_constructible
1065 : public __is_direct_constructible_new<_Tp, _Arg>::type
1068 // Since default-construction and binary direct-initialization have
1069 // been handled separately, the implementation of the remaining
1070 // n-ary construction cases is rather straightforward. We can use
1071 // here a functional cast, because array types are excluded anyway
1072 // and this form is never interpreted as a C cast.
1073 struct __do_is_nary_constructible_impl
1075 template<typename _Tp, typename... _Args, typename
1076 = decltype(_Tp(declval<_Args>()...))>
1077 static true_type __test(int);
1079 template<typename, typename...>
1080 static false_type __test(...);
1083 template<typename _Tp, typename... _Args>
1084 struct __is_nary_constructible_impl
1085 : public __do_is_nary_constructible_impl
1087 typedef decltype(__test<_Tp, _Args...>(0)) type;
1090 template<typename _Tp, typename... _Args>
1091 struct __is_nary_constructible
1092 : public __is_nary_constructible_impl<_Tp, _Args...>::type
1094 static_assert(sizeof...(_Args) > 1,
1095 "Only useful for > 1 arguments");
1098 template<typename _Tp, typename... _Args>
1099 struct __is_constructible_impl
1100 : public __is_nary_constructible<_Tp, _Args...>
1103 template<typename _Tp, typename _Arg>
1104 struct __is_constructible_impl<_Tp, _Arg>
1105 : public __is_direct_constructible<_Tp, _Arg>
1108 template<typename _Tp>
1109 struct __is_constructible_impl<_Tp>
1110 : public is_default_constructible<_Tp>
1113 /// is_constructible
1114 template<typename _Tp, typename... _Args>
1115 struct is_constructible
1116 : public __is_constructible_impl<_Tp, _Args...>::type
1119 template<typename _Tp, bool = __is_referenceable<_Tp>::value>
1120 struct __is_copy_constructible_impl;
1122 template<typename _Tp>
1123 struct __is_copy_constructible_impl<_Tp, false>
1124 : public false_type { };
1126 template<typename _Tp>
1127 struct __is_copy_constructible_impl<_Tp, true>
1128 : public is_constructible<_Tp, const _Tp&>
1131 /// is_copy_constructible
1132 template<typename _Tp>
1133 struct is_copy_constructible
1134 : public __is_copy_constructible_impl<_Tp>
1137 template<typename _Tp, bool = __is_referenceable<_Tp>::value>
1138 struct __is_move_constructible_impl;
1140 template<typename _Tp>
1141 struct __is_move_constructible_impl<_Tp, false>
1142 : public false_type { };
1144 template<typename _Tp>
1145 struct __is_move_constructible_impl<_Tp, true>
1146 : public is_constructible<_Tp, _Tp&&>
1149 /// is_move_constructible
1150 template<typename _Tp>
1151 struct is_move_constructible
1152 : public __is_move_constructible_impl<_Tp>
1155 template<typename _Tp>
1156 struct __is_nt_default_constructible_atom
1157 : public integral_constant<bool, noexcept(_Tp())>
1160 template<typename _Tp, bool = is_array<_Tp>::value>
1161 struct __is_nt_default_constructible_impl;
1163 template<typename _Tp>
1164 struct __is_nt_default_constructible_impl<_Tp, true>
1165 : public __and_<__is_array_known_bounds<_Tp>,
1166 __is_nt_default_constructible_atom<typename
1167 remove_all_extents<_Tp>::type>>
1170 template<typename _Tp>
1171 struct __is_nt_default_constructible_impl<_Tp, false>
1172 : public __is_nt_default_constructible_atom<_Tp>
1175 /// is_nothrow_default_constructible
1176 template<typename _Tp>
1177 struct is_nothrow_default_constructible
1178 : public __and_<is_default_constructible<_Tp>,
1179 __is_nt_default_constructible_impl<_Tp>>
1182 template<typename _Tp, typename... _Args>
1183 struct __is_nt_constructible_impl
1184 : public integral_constant<bool, noexcept(_Tp(declval<_Args>()...))>
1187 template<typename _Tp, typename _Arg>
1188 struct __is_nt_constructible_impl<_Tp, _Arg>
1189 : public integral_constant<bool,
1190 noexcept(static_cast<_Tp>(declval<_Arg>()))>
1193 template<typename _Tp>
1194 struct __is_nt_constructible_impl<_Tp>
1195 : public is_nothrow_default_constructible<_Tp>
1198 /// is_nothrow_constructible
1199 template<typename _Tp, typename... _Args>
1200 struct is_nothrow_constructible
1201 : public __and_<is_constructible<_Tp, _Args...>,
1202 __is_nt_constructible_impl<_Tp, _Args...>>
1205 template<typename _Tp, bool = __is_referenceable<_Tp>::value>
1206 struct __is_nothrow_copy_constructible_impl;
1208 template<typename _Tp>
1209 struct __is_nothrow_copy_constructible_impl<_Tp, false>
1210 : public false_type { };
1212 template<typename _Tp>
1213 struct __is_nothrow_copy_constructible_impl<_Tp, true>
1214 : public is_nothrow_constructible<_Tp, const _Tp&>
1217 /// is_nothrow_copy_constructible
1218 template<typename _Tp>
1219 struct is_nothrow_copy_constructible
1220 : public __is_nothrow_copy_constructible_impl<_Tp>
1223 template<typename _Tp, bool = __is_referenceable<_Tp>::value>
1224 struct __is_nothrow_move_constructible_impl;
1226 template<typename _Tp>
1227 struct __is_nothrow_move_constructible_impl<_Tp, false>
1228 : public false_type { };
1230 template<typename _Tp>
1231 struct __is_nothrow_move_constructible_impl<_Tp, true>
1232 : public is_nothrow_constructible<_Tp, _Tp&&>
1235 /// is_nothrow_move_constructible
1236 template<typename _Tp>
1237 struct is_nothrow_move_constructible
1238 : public __is_nothrow_move_constructible_impl<_Tp>
1241 template<typename _Tp, typename _Up>
1242 class __is_assignable_helper
1244 template<typename _Tp1, typename _Up1,
1245 typename = decltype(declval<_Tp1>() = declval<_Up1>())>
1249 template<typename, typename>
1254 typedef decltype(__test<_Tp, _Up>(0)) type;
1258 template<typename _Tp, typename _Up>
1259 struct is_assignable
1260 : public __is_assignable_helper<_Tp, _Up>::type
1263 template<typename _Tp, bool = __is_referenceable<_Tp>::value>
1264 struct __is_copy_assignable_impl;
1266 template<typename _Tp>
1267 struct __is_copy_assignable_impl<_Tp, false>
1268 : public false_type { };
1270 template<typename _Tp>
1271 struct __is_copy_assignable_impl<_Tp, true>
1272 : public is_assignable<_Tp&, const _Tp&>
1275 /// is_copy_assignable
1276 template<typename _Tp>
1277 struct is_copy_assignable
1278 : public __is_copy_assignable_impl<_Tp>
1281 template<typename _Tp, bool = __is_referenceable<_Tp>::value>
1282 struct __is_move_assignable_impl;
1284 template<typename _Tp>
1285 struct __is_move_assignable_impl<_Tp, false>
1286 : public false_type { };
1288 template<typename _Tp>
1289 struct __is_move_assignable_impl<_Tp, true>
1290 : public is_assignable<_Tp&, _Tp&&>
1293 /// is_move_assignable
1294 template<typename _Tp>
1295 struct is_move_assignable
1296 : public __is_move_assignable_impl<_Tp>
1299 template<typename _Tp, typename _Up>
1300 struct __is_nt_assignable_impl
1301 : public integral_constant<bool, noexcept(declval<_Tp>() = declval<_Up>())>
1304 /// is_nothrow_assignable
1305 template<typename _Tp, typename _Up>
1306 struct is_nothrow_assignable
1307 : public __and_<is_assignable<_Tp, _Up>,
1308 __is_nt_assignable_impl<_Tp, _Up>>
1311 template<typename _Tp, bool = __is_referenceable<_Tp>::value>
1312 struct __is_nt_copy_assignable_impl;
1314 template<typename _Tp>
1315 struct __is_nt_copy_assignable_impl<_Tp, false>
1316 : public false_type { };
1318 template<typename _Tp>
1319 struct __is_nt_copy_assignable_impl<_Tp, true>
1320 : public is_nothrow_assignable<_Tp&, const _Tp&>
1323 /// is_nothrow_copy_assignable
1324 template<typename _Tp>
1325 struct is_nothrow_copy_assignable
1326 : public __is_nt_copy_assignable_impl<_Tp>
1329 template<typename _Tp, bool = __is_referenceable<_Tp>::value>
1330 struct __is_nt_move_assignable_impl;
1332 template<typename _Tp>
1333 struct __is_nt_move_assignable_impl<_Tp, false>
1334 : public false_type { };
1336 template<typename _Tp>
1337 struct __is_nt_move_assignable_impl<_Tp, true>
1338 : public is_nothrow_assignable<_Tp&, _Tp&&>
1341 /// is_nothrow_move_assignable
1342 template<typename _Tp>
1343 struct is_nothrow_move_assignable
1344 : public __is_nt_move_assignable_impl<_Tp>
1347 /// is_trivially_constructible
1348 template<typename _Tp, typename... _Args>
1349 struct is_trivially_constructible
1350 : public __and_<is_constructible<_Tp, _Args...>, integral_constant<bool,
1351 __is_trivially_constructible(_Tp, _Args...)>>
1354 /// is_trivially_default_constructible
1355 template<typename _Tp>
1356 struct is_trivially_default_constructible
1357 : public is_trivially_constructible<_Tp>::type
1360 struct __do_is_implicitly_default_constructible_impl
1362 template <typename _Tp>
1363 static void __helper(const _Tp&);
1365 template <typename _Tp>
1366 static true_type __test(const _Tp&,
1367 decltype(__helper<const _Tp&>({}))* = 0);
1369 static false_type __test(...);
1372 template<typename _Tp>
1373 struct __is_implicitly_default_constructible_impl
1374 : public __do_is_implicitly_default_constructible_impl
1376 typedef decltype(__test(declval<_Tp>())) type;
1379 template<typename _Tp>
1380 struct __is_implicitly_default_constructible_safe
1381 : public __is_implicitly_default_constructible_impl<_Tp>::type
1384 template <typename _Tp>
1385 struct __is_implicitly_default_constructible
1386 : public __and_<is_default_constructible<_Tp>,
1387 __is_implicitly_default_constructible_safe<_Tp>>
1390 /// is_trivially_copy_constructible
1391 template<typename _Tp>
1392 struct is_trivially_copy_constructible
1393 : public __and_<is_copy_constructible<_Tp>,
1394 integral_constant<bool,
1395 __is_trivially_constructible(_Tp, const _Tp&)>>
1398 /// is_trivially_move_constructible
1399 template<typename _Tp>
1400 struct is_trivially_move_constructible
1401 : public __and_<is_move_constructible<_Tp>,
1402 integral_constant<bool,
1403 __is_trivially_constructible(_Tp, _Tp&&)>>
1406 /// is_trivially_assignable
1407 template<typename _Tp, typename _Up>
1408 struct is_trivially_assignable
1409 : public __and_<is_assignable<_Tp, _Up>,
1410 integral_constant<bool,
1411 __is_trivially_assignable(_Tp, _Up)>>
1414 /// is_trivially_copy_assignable
1415 template<typename _Tp>
1416 struct is_trivially_copy_assignable
1417 : public __and_<is_copy_assignable<_Tp>,
1418 integral_constant<bool,
1419 __is_trivially_assignable(_Tp&, const _Tp&)>>
1422 /// is_trivially_move_assignable
1423 template<typename _Tp>
1424 struct is_trivially_move_assignable
1425 : public __and_<is_move_assignable<_Tp>,
1426 integral_constant<bool,
1427 __is_trivially_assignable(_Tp&, _Tp&&)>>
1430 /// is_trivially_destructible
1431 template<typename _Tp>
1432 struct is_trivially_destructible
1433 : public __and_<is_destructible<_Tp>, integral_constant<bool,
1434 __has_trivial_destructor(_Tp)>>
1437 /// has_trivial_default_constructor (temporary legacy)
1438 template<typename _Tp>
1439 struct has_trivial_default_constructor
1440 : public integral_constant<bool, __has_trivial_constructor(_Tp)>
1441 { } _GLIBCXX_DEPRECATED;
1443 /// has_trivial_copy_constructor (temporary legacy)
1444 template<typename _Tp>
1445 struct has_trivial_copy_constructor
1446 : public integral_constant<bool, __has_trivial_copy(_Tp)>
1447 { } _GLIBCXX_DEPRECATED;
1449 /// has_trivial_copy_assign (temporary legacy)
1450 template<typename _Tp>
1451 struct has_trivial_copy_assign
1452 : public integral_constant<bool, __has_trivial_assign(_Tp)>
1453 { } _GLIBCXX_DEPRECATED;
1455 /// has_virtual_destructor
1456 template<typename _Tp>
1457 struct has_virtual_destructor
1458 : public integral_constant<bool, __has_virtual_destructor(_Tp)>
1462 // type property queries.
1465 template<typename _Tp>
1467 : public integral_constant<std::size_t, __alignof__(_Tp)> { };
1472 : public integral_constant<std::size_t, 0> { };
1474 template<typename _Tp, std::size_t _Size>
1475 struct rank<_Tp[_Size]>
1476 : public integral_constant<std::size_t, 1 + rank<_Tp>::value> { };
1478 template<typename _Tp>
1480 : public integral_constant<std::size_t, 1 + rank<_Tp>::value> { };
1483 template<typename, unsigned _Uint>
1485 : public integral_constant<std::size_t, 0> { };
1487 template<typename _Tp, unsigned _Uint, std::size_t _Size>
1488 struct extent<_Tp[_Size], _Uint>
1489 : public integral_constant<std::size_t,
1490 _Uint == 0 ? _Size : extent<_Tp,
1494 template<typename _Tp, unsigned _Uint>
1495 struct extent<_Tp[], _Uint>
1496 : public integral_constant<std::size_t,
1497 _Uint == 0 ? 0 : extent<_Tp,
1505 template<typename, typename>
1507 : public false_type { };
1509 template<typename _Tp>
1510 struct is_same<_Tp, _Tp>
1511 : public true_type { };
1514 template<typename _Base, typename _Derived>
1516 : public integral_constant<bool, __is_base_of(_Base, _Derived)>
1519 template<typename _From, typename _To,
1520 bool = __or_<is_void<_From>, is_function<_To>,
1521 is_array<_To>>::value>
1522 struct __is_convertible_helper
1523 { typedef typename is_void<_To>::type type; };
1525 template<typename _From, typename _To>
1526 class __is_convertible_helper<_From, _To, false>
1528 template<typename _To1>
1529 static void __test_aux(_To1);
1531 template<typename _From1, typename _To1,
1532 typename = decltype(__test_aux<_To1>(std::declval<_From1>()))>
1536 template<typename, typename>
1541 typedef decltype(__test<_From, _To>(0)) type;
1546 template<typename _From, typename _To>
1547 struct is_convertible
1548 : public __is_convertible_helper<_From, _To>::type
1552 // Const-volatile modifications.
1555 template<typename _Tp>
1557 { typedef _Tp type; };
1559 template<typename _Tp>
1560 struct remove_const<_Tp const>
1561 { typedef _Tp type; };
1564 template<typename _Tp>
1565 struct remove_volatile
1566 { typedef _Tp type; };
1568 template<typename _Tp>
1569 struct remove_volatile<_Tp volatile>
1570 { typedef _Tp type; };
1573 template<typename _Tp>
1577 remove_const<typename remove_volatile<_Tp>::type>::type type;
1581 template<typename _Tp>
1583 { typedef _Tp const type; };
1586 template<typename _Tp>
1588 { typedef _Tp volatile type; };
1591 template<typename _Tp>
1595 add_const<typename add_volatile<_Tp>::type>::type type;
1598 #if __cplusplus > 201103L
1600 #define __cpp_lib_transformation_trait_aliases 201304
1602 /// Alias template for remove_const
1603 template<typename _Tp>
1604 using remove_const_t = typename remove_const<_Tp>::type;
1606 /// Alias template for remove_volatile
1607 template<typename _Tp>
1608 using remove_volatile_t = typename remove_volatile<_Tp>::type;
1610 /// Alias template for remove_cv
1611 template<typename _Tp>
1612 using remove_cv_t = typename remove_cv<_Tp>::type;
1614 /// Alias template for add_const
1615 template<typename _Tp>
1616 using add_const_t = typename add_const<_Tp>::type;
1618 /// Alias template for add_volatile
1619 template<typename _Tp>
1620 using add_volatile_t = typename add_volatile<_Tp>::type;
1622 /// Alias template for add_cv
1623 template<typename _Tp>
1624 using add_cv_t = typename add_cv<_Tp>::type;
1627 // Reference transformations.
1629 /// remove_reference
1630 template<typename _Tp>
1631 struct remove_reference
1632 { typedef _Tp type; };
1634 template<typename _Tp>
1635 struct remove_reference<_Tp&>
1636 { typedef _Tp type; };
1638 template<typename _Tp>
1639 struct remove_reference<_Tp&&>
1640 { typedef _Tp type; };
1642 template<typename _Tp, bool = __is_referenceable<_Tp>::value>
1643 struct __add_lvalue_reference_helper
1644 { typedef _Tp type; };
1646 template<typename _Tp>
1647 struct __add_lvalue_reference_helper<_Tp, true>
1648 { typedef _Tp& type; };
1650 /// add_lvalue_reference
1651 template<typename _Tp>
1652 struct add_lvalue_reference
1653 : public __add_lvalue_reference_helper<_Tp>
1656 template<typename _Tp, bool = __is_referenceable<_Tp>::value>
1657 struct __add_rvalue_reference_helper
1658 { typedef _Tp type; };
1660 template<typename _Tp>
1661 struct __add_rvalue_reference_helper<_Tp, true>
1662 { typedef _Tp&& type; };
1664 /// add_rvalue_reference
1665 template<typename _Tp>
1666 struct add_rvalue_reference
1667 : public __add_rvalue_reference_helper<_Tp>
1670 #if __cplusplus > 201103L
1671 /// Alias template for remove_reference
1672 template<typename _Tp>
1673 using remove_reference_t = typename remove_reference<_Tp>::type;
1675 /// Alias template for add_lvalue_reference
1676 template<typename _Tp>
1677 using add_lvalue_reference_t = typename add_lvalue_reference<_Tp>::type;
1679 /// Alias template for add_rvalue_reference
1680 template<typename _Tp>
1681 using add_rvalue_reference_t = typename add_rvalue_reference<_Tp>::type;
1684 // Sign modifications.
1686 // Utility for constructing identically cv-qualified types.
1687 template<typename _Unqualified, bool _IsConst, bool _IsVol>
1688 struct __cv_selector;
1690 template<typename _Unqualified>
1691 struct __cv_selector<_Unqualified, false, false>
1692 { typedef _Unqualified __type; };
1694 template<typename _Unqualified>
1695 struct __cv_selector<_Unqualified, false, true>
1696 { typedef volatile _Unqualified __type; };
1698 template<typename _Unqualified>
1699 struct __cv_selector<_Unqualified, true, false>
1700 { typedef const _Unqualified __type; };
1702 template<typename _Unqualified>
1703 struct __cv_selector<_Unqualified, true, true>
1704 { typedef const volatile _Unqualified __type; };
1706 template<typename _Qualified, typename _Unqualified,
1707 bool _IsConst = is_const<_Qualified>::value,
1708 bool _IsVol = is_volatile<_Qualified>::value>
1709 class __match_cv_qualifiers
1711 typedef __cv_selector<_Unqualified, _IsConst, _IsVol> __match;
1714 typedef typename __match::__type __type;
1717 // Utility for finding the unsigned versions of signed integral types.
1718 template<typename _Tp>
1719 struct __make_unsigned
1720 { typedef _Tp __type; };
1723 struct __make_unsigned<char>
1724 { typedef unsigned char __type; };
1727 struct __make_unsigned<signed char>
1728 { typedef unsigned char __type; };
1731 struct __make_unsigned<short>
1732 { typedef unsigned short __type; };
1735 struct __make_unsigned<int>
1736 { typedef unsigned int __type; };
1739 struct __make_unsigned<long>
1740 { typedef unsigned long __type; };
1743 struct __make_unsigned<long long>
1744 { typedef unsigned long long __type; };
1746 #if defined(_GLIBCXX_USE_WCHAR_T) && !defined(__WCHAR_UNSIGNED__)
1748 struct __make_unsigned<wchar_t> : __make_unsigned<__WCHAR_TYPE__>
1752 #if defined(__GLIBCXX_TYPE_INT_N_0)
1754 struct __make_unsigned<__GLIBCXX_TYPE_INT_N_0>
1755 { typedef unsigned __GLIBCXX_TYPE_INT_N_0 __type; };
1757 #if defined(__GLIBCXX_TYPE_INT_N_1)
1759 struct __make_unsigned<__GLIBCXX_TYPE_INT_N_1>
1760 { typedef unsigned __GLIBCXX_TYPE_INT_N_1 __type; };
1762 #if defined(__GLIBCXX_TYPE_INT_N_2)
1764 struct __make_unsigned<__GLIBCXX_TYPE_INT_N_2>
1765 { typedef unsigned __GLIBCXX_TYPE_INT_N_2 __type; };
1767 #if defined(__GLIBCXX_TYPE_INT_N_3)
1769 struct __make_unsigned<__GLIBCXX_TYPE_INT_N_3>
1770 { typedef unsigned __GLIBCXX_TYPE_INT_N_3 __type; };
1773 // Select between integral and enum: not possible to be both.
1774 template<typename _Tp,
1775 bool _IsInt = is_integral<_Tp>::value,
1776 bool _IsEnum = is_enum<_Tp>::value>
1777 class __make_unsigned_selector;
1779 template<typename _Tp>
1780 class __make_unsigned_selector<_Tp, true, false>
1782 typedef __make_unsigned<typename remove_cv<_Tp>::type> __unsignedt;
1783 typedef typename __unsignedt::__type __unsigned_type;
1784 typedef __match_cv_qualifiers<_Tp, __unsigned_type> __cv_unsigned;
1787 typedef typename __cv_unsigned::__type __type;
1790 template<typename _Tp>
1791 class __make_unsigned_selector<_Tp, false, true>
1793 // With -fshort-enums, an enum may be as small as a char.
1794 typedef unsigned char __smallest;
1795 static const bool __b0 = sizeof(_Tp) <= sizeof(__smallest);
1796 static const bool __b1 = sizeof(_Tp) <= sizeof(unsigned short);
1797 static const bool __b2 = sizeof(_Tp) <= sizeof(unsigned int);
1798 static const bool __b3 = sizeof(_Tp) <= sizeof(unsigned long);
1799 typedef conditional<__b3, unsigned long, unsigned long long> __cond3;
1800 typedef typename __cond3::type __cond3_type;
1801 typedef conditional<__b2, unsigned int, __cond3_type> __cond2;
1802 typedef typename __cond2::type __cond2_type;
1803 typedef conditional<__b1, unsigned short, __cond2_type> __cond1;
1804 typedef typename __cond1::type __cond1_type;
1806 typedef typename conditional<__b0, __smallest, __cond1_type>::type
1808 typedef __match_cv_qualifiers<_Tp, __unsigned_type> __cv_unsigned;
1811 typedef typename __cv_unsigned::__type __type;
1814 // Given an integral/enum type, return the corresponding unsigned
1816 // Primary template.
1818 template<typename _Tp>
1819 struct make_unsigned
1820 { typedef typename __make_unsigned_selector<_Tp>::__type type; };
1822 // Integral, but don't define.
1824 struct make_unsigned<bool>;
1827 // Utility for finding the signed versions of unsigned integral types.
1828 template<typename _Tp>
1829 struct __make_signed
1830 { typedef _Tp __type; };
1833 struct __make_signed<char>
1834 { typedef signed char __type; };
1837 struct __make_signed<unsigned char>
1838 { typedef signed char __type; };
1841 struct __make_signed<unsigned short>
1842 { typedef signed short __type; };
1845 struct __make_signed<unsigned int>
1846 { typedef signed int __type; };
1849 struct __make_signed<unsigned long>
1850 { typedef signed long __type; };
1853 struct __make_signed<unsigned long long>
1854 { typedef signed long long __type; };
1856 #if defined(_GLIBCXX_USE_WCHAR_T) && defined(__WCHAR_UNSIGNED__)
1858 struct __make_signed<wchar_t> : __make_signed<__WCHAR_TYPE__>
1862 #ifdef _GLIBCXX_USE_C99_STDINT_TR1
1864 struct __make_signed<char16_t> : __make_signed<uint_least16_t>
1867 struct __make_signed<char32_t> : __make_signed<uint_least32_t>
1871 #if defined(__GLIBCXX_TYPE_INT_N_0)
1873 struct __make_signed<unsigned __GLIBCXX_TYPE_INT_N_0>
1874 { typedef __GLIBCXX_TYPE_INT_N_0 __type; };
1876 #if defined(__GLIBCXX_TYPE_INT_N_1)
1878 struct __make_signed<unsigned __GLIBCXX_TYPE_INT_N_1>
1879 { typedef __GLIBCXX_TYPE_INT_N_1 __type; };
1881 #if defined(__GLIBCXX_TYPE_INT_N_2)
1883 struct __make_signed<unsigned __GLIBCXX_TYPE_INT_N_2>
1884 { typedef __GLIBCXX_TYPE_INT_N_2 __type; };
1886 #if defined(__GLIBCXX_TYPE_INT_N_3)
1888 struct __make_signed<unsigned __GLIBCXX_TYPE_INT_N_3>
1889 { typedef __GLIBCXX_TYPE_INT_N_3 __type; };
1892 // Select between integral and enum: not possible to be both.
1893 template<typename _Tp,
1894 bool _IsInt = is_integral<_Tp>::value,
1895 bool _IsEnum = is_enum<_Tp>::value>
1896 class __make_signed_selector;
1898 template<typename _Tp>
1899 class __make_signed_selector<_Tp, true, false>
1901 typedef __make_signed<typename remove_cv<_Tp>::type> __signedt;
1902 typedef typename __signedt::__type __signed_type;
1903 typedef __match_cv_qualifiers<_Tp, __signed_type> __cv_signed;
1906 typedef typename __cv_signed::__type __type;
1909 template<typename _Tp>
1910 class __make_signed_selector<_Tp, false, true>
1912 typedef typename __make_unsigned_selector<_Tp>::__type __unsigned_type;
1915 typedef typename __make_signed_selector<__unsigned_type>::__type __type;
1918 // Given an integral/enum type, return the corresponding signed
1920 // Primary template.
1922 template<typename _Tp>
1924 { typedef typename __make_signed_selector<_Tp>::__type type; };
1926 // Integral, but don't define.
1928 struct make_signed<bool>;
1930 #if __cplusplus > 201103L
1931 /// Alias template for make_signed
1932 template<typename _Tp>
1933 using make_signed_t = typename make_signed<_Tp>::type;
1935 /// Alias template for make_unsigned
1936 template<typename _Tp>
1937 using make_unsigned_t = typename make_unsigned<_Tp>::type;
1940 // Array modifications.
1943 template<typename _Tp>
1944 struct remove_extent
1945 { typedef _Tp type; };
1947 template<typename _Tp, std::size_t _Size>
1948 struct remove_extent<_Tp[_Size]>
1949 { typedef _Tp type; };
1951 template<typename _Tp>
1952 struct remove_extent<_Tp[]>
1953 { typedef _Tp type; };
1955 /// remove_all_extents
1956 template<typename _Tp>
1957 struct remove_all_extents
1958 { typedef _Tp type; };
1960 template<typename _Tp, std::size_t _Size>
1961 struct remove_all_extents<_Tp[_Size]>
1962 { typedef typename remove_all_extents<_Tp>::type type; };
1964 template<typename _Tp>
1965 struct remove_all_extents<_Tp[]>
1966 { typedef typename remove_all_extents<_Tp>::type type; };
1968 #if __cplusplus > 201103L
1969 /// Alias template for remove_extent
1970 template<typename _Tp>
1971 using remove_extent_t = typename remove_extent<_Tp>::type;
1973 /// Alias template for remove_all_extents
1974 template<typename _Tp>
1975 using remove_all_extents_t = typename remove_all_extents<_Tp>::type;
1978 // Pointer modifications.
1980 template<typename _Tp, typename>
1981 struct __remove_pointer_helper
1982 { typedef _Tp type; };
1984 template<typename _Tp, typename _Up>
1985 struct __remove_pointer_helper<_Tp, _Up*>
1986 { typedef _Up type; };
1989 template<typename _Tp>
1990 struct remove_pointer
1991 : public __remove_pointer_helper<_Tp, typename remove_cv<_Tp>::type>
1995 template<typename _Tp, bool = __or_<__is_referenceable<_Tp>,
1996 is_void<_Tp>>::value>
1997 struct __add_pointer_helper
1998 { typedef _Tp type; };
2000 template<typename _Tp>
2001 struct __add_pointer_helper<_Tp, true>
2002 { typedef typename remove_reference<_Tp>::type* type; };
2004 template<typename _Tp>
2006 : public __add_pointer_helper<_Tp>
2009 #if __cplusplus > 201103L
2010 /// Alias template for remove_pointer
2011 template<typename _Tp>
2012 using remove_pointer_t = typename remove_pointer<_Tp>::type;
2014 /// Alias template for add_pointer
2015 template<typename _Tp>
2016 using add_pointer_t = typename add_pointer<_Tp>::type;
2019 template<std::size_t _Len>
2020 struct __aligned_storage_msa
2024 unsigned char __data[_Len];
2025 struct __attribute__((__aligned__)) { } __align;
2030 * @brief Alignment type.
2032 * The value of _Align is a default-alignment which shall be the
2033 * most stringent alignment requirement for any C++ object type
2034 * whose size is no greater than _Len (3.9). The member typedef
2035 * type shall be a POD type suitable for use as uninitialized
2036 * storage for any object whose size is at most _Len and whose
2037 * alignment is a divisor of _Align.
2039 template<std::size_t _Len, std::size_t _Align =
2040 __alignof__(typename __aligned_storage_msa<_Len>::__type)>
2041 struct aligned_storage
2045 unsigned char __data[_Len];
2046 struct __attribute__((__aligned__((_Align)))) { } __align;
2050 template <typename... _Types>
2051 struct __strictest_alignment
2053 static const size_t _S_alignment = 0;
2054 static const size_t _S_size = 0;
2057 template <typename _Tp, typename... _Types>
2058 struct __strictest_alignment<_Tp, _Types...>
2060 static const size_t _S_alignment =
2061 alignof(_Tp) > __strictest_alignment<_Types...>::_S_alignment
2062 ? alignof(_Tp) : __strictest_alignment<_Types...>::_S_alignment;
2063 static const size_t _S_size =
2064 sizeof(_Tp) > __strictest_alignment<_Types...>::_S_size
2065 ? sizeof(_Tp) : __strictest_alignment<_Types...>::_S_size;
2069 * @brief Provide aligned storage for types.
2071 * [meta.trans.other]
2073 * Provides aligned storage for any of the provided types of at
2076 * @see aligned_storage
2078 template <size_t _Len, typename... _Types>
2079 struct aligned_union
2082 static_assert(sizeof...(_Types) != 0, "At least one type is required");
2084 using __strictest = __strictest_alignment<_Types...>;
2085 static const size_t _S_len = _Len > __strictest::_S_size
2086 ? _Len : __strictest::_S_size;
2088 /// The value of the strictest alignment of _Types.
2089 static const size_t alignment_value = __strictest::_S_alignment;
2091 typedef typename aligned_storage<_S_len, alignment_value>::type type;
2094 template <size_t _Len, typename... _Types>
2095 const size_t aligned_union<_Len, _Types...>::alignment_value;
2097 // Decay trait for arrays and functions, used for perfect forwarding
2098 // in make_pair, make_tuple, etc.
2099 template<typename _Up,
2100 bool _IsArray = is_array<_Up>::value,
2101 bool _IsFunction = is_function<_Up>::value>
2102 struct __decay_selector;
2105 template<typename _Up>
2106 struct __decay_selector<_Up, false, false>
2107 { typedef typename remove_cv<_Up>::type __type; };
2109 template<typename _Up>
2110 struct __decay_selector<_Up, true, false>
2111 { typedef typename remove_extent<_Up>::type* __type; };
2113 template<typename _Up>
2114 struct __decay_selector<_Up, false, true>
2115 { typedef typename add_pointer<_Up>::type __type; };
2118 template<typename _Tp>
2121 typedef typename remove_reference<_Tp>::type __remove_type;
2124 typedef typename __decay_selector<__remove_type>::__type type;
2127 template<typename _Tp>
2128 class reference_wrapper;
2130 // Helper which adds a reference to a type when given a reference_wrapper
2131 template<typename _Tp>
2132 struct __strip_reference_wrapper
2137 template<typename _Tp>
2138 struct __strip_reference_wrapper<reference_wrapper<_Tp> >
2140 typedef _Tp& __type;
2143 template<typename _Tp>
2144 struct __decay_and_strip
2146 typedef typename __strip_reference_wrapper<
2147 typename decay<_Tp>::type>::__type __type;
2151 // Primary template.
2152 /// Define a member typedef @c type only if a boolean constant is true.
2153 template<bool, typename _Tp = void>
2157 // Partial specialization for true.
2158 template<typename _Tp>
2159 struct enable_if<true, _Tp>
2160 { typedef _Tp type; };
2162 template<typename... _Cond>
2163 using _Require = typename enable_if<__and_<_Cond...>::value>::type;
2165 // Primary template.
2166 /// Define a member typedef @c type to one of two argument types.
2167 template<bool _Cond, typename _Iftrue, typename _Iffalse>
2169 { typedef _Iftrue type; };
2171 // Partial specialization for false.
2172 template<typename _Iftrue, typename _Iffalse>
2173 struct conditional<false, _Iftrue, _Iffalse>
2174 { typedef _Iffalse type; };
2177 template<typename... _Tp>
2180 // Sfinae-friendly common_type implementation:
2182 struct __do_common_type_impl
2184 template<typename _Tp, typename _Up>
2185 static __success_type<typename decay<decltype
2186 (true ? std::declval<_Tp>()
2187 : std::declval<_Up>())>::type> _S_test(int);
2189 template<typename, typename>
2190 static __failure_type _S_test(...);
2193 template<typename _Tp, typename _Up>
2194 struct __common_type_impl
2195 : private __do_common_type_impl
2197 typedef decltype(_S_test<_Tp, _Up>(0)) type;
2200 struct __do_member_type_wrapper
2202 template<typename _Tp>
2203 static __success_type<typename _Tp::type> _S_test(int);
2206 static __failure_type _S_test(...);
2209 template<typename _Tp>
2210 struct __member_type_wrapper
2211 : private __do_member_type_wrapper
2213 typedef decltype(_S_test<_Tp>(0)) type;
2216 template<typename _CTp, typename... _Args>
2217 struct __expanded_common_type_wrapper
2219 typedef common_type<typename _CTp::type, _Args...> type;
2222 template<typename... _Args>
2223 struct __expanded_common_type_wrapper<__failure_type, _Args...>
2224 { typedef __failure_type type; };
2226 template<typename _Tp>
2227 struct common_type<_Tp>
2228 { typedef typename decay<_Tp>::type type; };
2230 template<typename _Tp, typename _Up>
2231 struct common_type<_Tp, _Up>
2232 : public __common_type_impl<_Tp, _Up>::type
2235 template<typename _Tp, typename _Up, typename... _Vp>
2236 struct common_type<_Tp, _Up, _Vp...>
2237 : public __expanded_common_type_wrapper<typename __member_type_wrapper<
2238 common_type<_Tp, _Up>>::type, _Vp...>::type
2241 /// The underlying type of an enum.
2242 template<typename _Tp>
2243 struct underlying_type
2245 typedef __underlying_type(_Tp) type;
2248 template<typename _Tp>
2249 struct __declval_protector
2251 static const bool __stop = false;
2252 static typename add_rvalue_reference<_Tp>::type __delegate();
2255 template<typename _Tp>
2256 inline typename add_rvalue_reference<_Tp>::type
2259 static_assert(__declval_protector<_Tp>::__stop,
2260 "declval() must not be used!");
2261 return __declval_protector<_Tp>::__delegate();
2265 template<typename _Signature>
2268 // Sfinae-friendly result_of implementation:
2270 #define __cpp_lib_result_of_sfinae 201210
2272 struct __invoke_memfun_ref { };
2273 struct __invoke_memfun_deref { };
2274 struct __invoke_memobj_ref { };
2275 struct __invoke_memobj_deref { };
2276 struct __invoke_other { };
2278 // Associate a tag type with a specialization of __success_type.
2279 template<typename _Tp, typename _Tag>
2280 struct __result_of_success : __success_type<_Tp>
2281 { using __invoke_type = _Tag; };
2283 // [func.require] paragraph 1 bullet 1:
2284 struct __result_of_memfun_ref_impl
2286 template<typename _Fp, typename _Tp1, typename... _Args>
2287 static __result_of_success<decltype(
2288 (std::declval<_Tp1>().*std::declval<_Fp>())(std::declval<_Args>()...)
2289 ), __invoke_memfun_ref> _S_test(int);
2291 template<typename...>
2292 static __failure_type _S_test(...);
2295 template<typename _MemPtr, typename _Arg, typename... _Args>
2296 struct __result_of_memfun_ref
2297 : private __result_of_memfun_ref_impl
2299 typedef decltype(_S_test<_MemPtr, _Arg, _Args...>(0)) type;
2302 // [func.require] paragraph 1 bullet 2:
2303 struct __result_of_memfun_deref_impl
2305 template<typename _Fp, typename _Tp1, typename... _Args>
2306 static __result_of_success<decltype(
2307 ((*std::declval<_Tp1>()).*std::declval<_Fp>())(std::declval<_Args>()...)
2308 ), __invoke_memfun_deref> _S_test(int);
2310 template<typename...>
2311 static __failure_type _S_test(...);
2314 template<typename _MemPtr, typename _Arg, typename... _Args>
2315 struct __result_of_memfun_deref
2316 : private __result_of_memfun_deref_impl
2318 typedef decltype(_S_test<_MemPtr, _Arg, _Args...>(0)) type;
2321 // [func.require] paragraph 1 bullet 3:
2322 struct __result_of_memobj_ref_impl
2324 template<typename _Fp, typename _Tp1>
2325 static __result_of_success<decltype(
2326 std::declval<_Tp1>().*std::declval<_Fp>()
2327 ), __invoke_memobj_ref> _S_test(int);
2329 template<typename, typename>
2330 static __failure_type _S_test(...);
2333 template<typename _MemPtr, typename _Arg>
2334 struct __result_of_memobj_ref
2335 : private __result_of_memobj_ref_impl
2337 typedef decltype(_S_test<_MemPtr, _Arg>(0)) type;
2340 // [func.require] paragraph 1 bullet 4:
2341 struct __result_of_memobj_deref_impl
2343 template<typename _Fp, typename _Tp1>
2344 static __result_of_success<decltype(
2345 (*std::declval<_Tp1>()).*std::declval<_Fp>()
2346 ), __invoke_memobj_deref> _S_test(int);
2348 template<typename, typename>
2349 static __failure_type _S_test(...);
2352 template<typename _MemPtr, typename _Arg>
2353 struct __result_of_memobj_deref
2354 : private __result_of_memobj_deref_impl
2356 typedef decltype(_S_test<_MemPtr, _Arg>(0)) type;
2359 template<typename _MemPtr, typename _Arg>
2360 struct __result_of_memobj;
2362 template<typename _Res, typename _Class, typename _Arg>
2363 struct __result_of_memobj<_Res _Class::*, _Arg>
2365 typedef typename remove_cv<typename remove_reference<
2366 _Arg>::type>::type _Argval;
2367 typedef _Res _Class::* _MemPtr;
2368 typedef typename conditional<__or_<is_same<_Argval, _Class>,
2369 is_base_of<_Class, _Argval>>::value,
2370 __result_of_memobj_ref<_MemPtr, _Arg>,
2371 __result_of_memobj_deref<_MemPtr, _Arg>
2375 template<typename _MemPtr, typename _Arg, typename... _Args>
2376 struct __result_of_memfun;
2378 template<typename _Res, typename _Class, typename _Arg, typename... _Args>
2379 struct __result_of_memfun<_Res _Class::*, _Arg, _Args...>
2381 typedef typename remove_cv<typename remove_reference<
2382 _Arg>::type>::type _Argval;
2383 typedef _Res _Class::* _MemPtr;
2384 typedef typename conditional<__or_<is_same<_Argval, _Class>,
2385 is_base_of<_Class, _Argval>>::value,
2386 __result_of_memfun_ref<_MemPtr, _Arg, _Args...>,
2387 __result_of_memfun_deref<_MemPtr, _Arg, _Args...>
2391 // _GLIBCXX_RESOLVE_LIB_DEFECTS
2392 // 2219. INVOKE-ing a pointer to member with a reference_wrapper
2393 // as the object expression
2394 template<typename> struct reference_wrapper;
2396 template<typename _Res, typename _Class, typename _Arg>
2397 struct __result_of_memobj<_Res _Class::*, reference_wrapper<_Arg>>
2398 : __result_of_memobj<_Res _Class::*, _Arg>
2401 __result_of_memobj_ref<_Res _Class::*, _Arg&>::type type;
2404 template<typename _Res, typename _Class, typename _Arg>
2405 struct __result_of_memobj<_Res _Class::*, reference_wrapper<_Arg>&>
2406 : __result_of_memobj<_Res _Class::*, reference_wrapper<_Arg>>
2409 template<typename _Res, typename _Class, typename _Arg>
2410 struct __result_of_memobj<_Res _Class::*, reference_wrapper<_Arg>&&>
2411 : __result_of_memobj<_Res _Class::*, reference_wrapper<_Arg>>
2414 template<typename _Res, typename _Class, typename _Arg, typename... _Args>
2415 struct __result_of_memfun<_Res _Class::*, reference_wrapper<_Arg>, _Args...>
2416 : __result_of_memfun<_Res _Class::*, _Arg&, _Args...>
2419 __result_of_memfun_ref<_Res _Class::*, _Arg&, _Args...>::type type;
2422 template<typename _Res, typename _Class, typename _Arg, typename... _Args>
2423 struct __result_of_memfun<_Res _Class::*, reference_wrapper<_Arg>&,
2425 : __result_of_memfun<_Res _Class::*, reference_wrapper<_Arg>, _Args...>
2428 template<typename _Res, typename _Class, typename _Arg, typename... _Args>
2429 struct __result_of_memfun<_Res _Class::*, reference_wrapper<_Arg>&&,
2431 : __result_of_memfun<_Res _Class::*, reference_wrapper<_Arg>, _Args...>
2434 template<bool, bool, typename _Functor, typename... _ArgTypes>
2435 struct __result_of_impl
2437 typedef __failure_type type;
2440 template<typename _MemPtr, typename _Arg>
2441 struct __result_of_impl<true, false, _MemPtr, _Arg>
2442 : public __result_of_memobj<typename decay<_MemPtr>::type, _Arg>
2445 template<typename _MemPtr, typename _Arg, typename... _Args>
2446 struct __result_of_impl<false, true, _MemPtr, _Arg, _Args...>
2447 : public __result_of_memfun<typename decay<_MemPtr>::type, _Arg, _Args...>
2450 // [func.require] paragraph 1 bullet 5:
2451 struct __result_of_other_impl
2453 template<typename _Fn, typename... _Args>
2454 static __result_of_success<decltype(
2455 std::declval<_Fn>()(std::declval<_Args>()...)
2456 ), __invoke_other> _S_test(int);
2458 template<typename...>
2459 static __failure_type _S_test(...);
2462 template<typename _Functor, typename... _ArgTypes>
2463 struct __result_of_impl<false, false, _Functor, _ArgTypes...>
2464 : private __result_of_other_impl
2466 typedef decltype(_S_test<_Functor, _ArgTypes...>(0)) type;
2469 template<typename _Functor, typename... _ArgTypes>
2470 struct result_of<_Functor(_ArgTypes...)>
2471 : public __result_of_impl<
2472 is_member_object_pointer<
2473 typename remove_reference<_Functor>::type
2475 is_member_function_pointer<
2476 typename remove_reference<_Functor>::type
2478 _Functor, _ArgTypes...
2482 #if __cplusplus > 201103L
2483 /// Alias template for aligned_storage
2484 template<size_t _Len, size_t _Align =
2485 __alignof__(typename __aligned_storage_msa<_Len>::__type)>
2486 using aligned_storage_t = typename aligned_storage<_Len, _Align>::type;
2488 template <size_t _Len, typename... _Types>
2489 using aligned_union_t = typename aligned_union<_Len, _Types...>::type;
2491 /// Alias template for decay
2492 template<typename _Tp>
2493 using decay_t = typename decay<_Tp>::type;
2495 /// Alias template for enable_if
2496 template<bool _Cond, typename _Tp = void>
2497 using enable_if_t = typename enable_if<_Cond, _Tp>::type;
2499 /// Alias template for conditional
2500 template<bool _Cond, typename _Iftrue, typename _Iffalse>
2501 using conditional_t = typename conditional<_Cond, _Iftrue, _Iffalse>::type;
2503 /// Alias template for common_type
2504 template<typename... _Tp>
2505 using common_type_t = typename common_type<_Tp...>::type;
2507 /// Alias template for underlying_type
2508 template<typename _Tp>
2509 using underlying_type_t = typename underlying_type<_Tp>::type;
2511 /// Alias template for result_of
2512 template<typename _Tp>
2513 using result_of_t = typename result_of<_Tp>::type;
2516 template<typename...> using __void_t = void;
2518 #if __cplusplus > 201402L || !defined(__STRICT_ANSI__) // c++1z or gnu++11
2519 #define __cpp_lib_void_t 201411
2520 /// A metafunction that always yields void, used for detecting valid types.
2521 template<typename...> using void_t = void;
2524 /// Implementation of the detection idiom (negative case).
2525 template<typename _Default, typename _AlwaysVoid,
2526 template<typename...> class _Op, typename... _Args>
2529 using value_t = false_type;
2530 using type = _Default;
2533 /// Implementation of the detection idiom (positive case).
2534 template<typename _Default, template<typename...> class _Op,
2536 struct __detector<_Default, __void_t<_Op<_Args...>>, _Op, _Args...>
2538 using value_t = true_type;
2539 using type = _Op<_Args...>;
2542 // Detect whether _Op<_Args...> is a valid type, use _Default if not.
2543 template<typename _Default, template<typename...> class _Op,
2545 using __detected_or = __detector<_Default, void, _Op, _Args...>;
2547 // _Op<_Args...> if that is a valid type, otherwise _Default.
2548 template<typename _Default, template<typename...> class _Op,
2550 using __detected_or_t
2551 = typename __detected_or<_Default, _Op, _Args...>::type;
2553 // _Op<_Args...> if that is a valid type, otherwise _Default<_Args...>.
2554 template<template<typename...> class _Default,
2555 template<typename...> class _Op, typename... _Args>
2556 using __detected_or_t_ =
2557 __detected_or_t<_Default<_Args...>, _Op, _Args...>;
2559 /// @} group metaprogramming
2562 * Use SFINAE to determine if the type _Tp has a publicly-accessible
2563 * member type _NTYPE.
2565 #define _GLIBCXX_HAS_NESTED_TYPE(_NTYPE) \
2566 template<typename _Tp, typename = __void_t<>> \
2567 struct __has_##_NTYPE \
2570 template<typename _Tp> \
2571 struct __has_##_NTYPE<_Tp, __void_t<typename _Tp::_NTYPE>> \
2576 namespace __is_swappable_impl {
2577 template <typename _Tp, typename=void>
2578 struct __is_swappable : public false_type
2582 template<typename _Tp>
2584 typename enable_if<__and_<is_move_constructible<_Tp>,
2585 is_move_assignable<_Tp>>::value>::type
2587 noexcept(__and_<is_nothrow_move_constructible<_Tp>,
2588 is_nothrow_move_assignable<_Tp>>::value);
2590 template<typename _Tp, size_t _Nm>
2592 typename enable_if<__is_swappable_impl::__is_swappable<_Tp>::value>::type
2593 swap(_Tp (&__a)[_Nm], _Tp (&__b)[_Nm])
2594 noexcept(noexcept(swap(*__a, *__b)));
2596 namespace __is_swappable_impl {
2599 template <typename _Tp>
2600 struct __is_swappable<_Tp, __void_t<decltype(swap(declval<_Tp&>(),
2606 template <bool, typename _Tp>
2607 struct __is_nothrow_swappable_impl
2608 : public __bool_constant<noexcept(swap(declval<_Tp&>(), declval<_Tp&>()))>
2611 template <typename _Tp>
2612 struct __is_nothrow_swappable_impl<false, _Tp> : public false_type
2615 template <typename _Tp>
2616 struct __is_nothrow_swappable
2617 : public __is_nothrow_swappable_impl<
2618 __is_swappable_impl::__is_swappable<_Tp>::value, _Tp>
2621 _GLIBCXX_END_NAMESPACE_VERSION
2626 #endif // _GLIBCXX_TYPE_TRAITS