From: Jonathan Wakely Date: Thu, 1 Sep 2022 14:58:34 +0000 (+0100) Subject: libstdc++: Remove __is_referenceable helper X-Git-Tag: basepoints/gcc-14~4853 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=56bb34e3d2c800a7f13e65755bccfb6b2dc5e898;p=thirdparty%2Fgcc.git libstdc++: Remove __is_referenceable helper We only use the __is_referenceable helper in three places now: add_pointer, add_lvalue_reference, and add_rvalue_reference. But lots of other traits depend on add_[lr]value_reference, and decay depends on add_pointer, so removing the instantiation of __is_referenceable helps compile all those other traits slightly faster. We can just use void_t to check for a referenceable type in the add_[lr]value_reference traits. Then we can specialize add_pointer for reference types, so that we don't need to use remove_reference, and then use void_t for all non-reference types to detect when we can form a pointer to the type. libstdc++-v3/ChangeLog: * include/std/type_traits (__is_referenceable): Remove. (__add_lvalue_reference_helper, __add_rvalue_reference_helper): Use __void_t instead of __is_referenceable. (__add_pointer_helper): Likewise. (add_pointer): Add partial specializations for reference types. --- diff --git a/libstdc++-v3/include/std/type_traits b/libstdc++-v3/include/std/type_traits index 3041ac3c9414..8b11f31741b7 100644 --- a/libstdc++-v3/include/std/type_traits +++ b/libstdc++-v3/include/std/type_traits @@ -712,18 +712,6 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION // __void_t (std::void_t for C++11) template using __void_t = void; - - // Utility to detect referenceable types ([defns.referenceable]). - - template - struct __is_referenceable - : public false_type - { }; - - template - struct __is_referenceable<_Tp, __void_t<_Tp&>> - : public true_type - { }; /// @endcond // Type properties. @@ -1024,12 +1012,12 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION }; /// @cond undocumented - template::value> + template struct __add_lvalue_reference_helper { using type = _Tp; }; template - struct __add_lvalue_reference_helper<_Tp, true> + struct __add_lvalue_reference_helper<_Tp, __void_t<_Tp&>> { using type = _Tp&; }; template @@ -1046,12 +1034,12 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION }; /// @cond undocumented - template::value> + template struct __add_rvalue_reference_helper { using type = _Tp; }; template - struct __add_rvalue_reference_helper<_Tp, true> + struct __add_rvalue_reference_helper<_Tp, __void_t<_Tp&&>> { using type = _Tp&&; }; template @@ -1971,14 +1959,13 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION : public __remove_pointer_helper<_Tp, __remove_cv_t<_Tp>> { }; - template, - is_void<_Tp>>::value> + template struct __add_pointer_helper - { typedef _Tp type; }; + { using type = _Tp; }; template - struct __add_pointer_helper<_Tp, true> - { typedef typename remove_reference<_Tp>::type* type; }; + struct __add_pointer_helper<_Tp, __void_t<_Tp*>> + { using type = _Tp*; }; /// add_pointer template @@ -1986,6 +1973,14 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION : public __add_pointer_helper<_Tp> { }; + template + struct add_pointer<_Tp&> + { using type = _Tp*; }; + + template + struct add_pointer<_Tp&&> + { using type = _Tp*; }; + #if __cplusplus > 201103L /// Alias template for remove_pointer template