From cdcf2b9a6ceb87ad493875d9f3e0bcf7f6d11043 Mon Sep 17 00:00:00 2001 From: Jakub Mazurkiewicz Date: Wed, 4 Jan 2023 16:34:48 +0100 Subject: [PATCH] Add workaround for clang bug (llvm/llvm-project#59827) --- stl/inc/utility | 25 +++++++++++++++++-------- 1 file changed, 17 insertions(+), 8 deletions(-) diff --git a/stl/inc/utility b/stl/inc/utility index dc082e3f91..5334f6d427 100644 --- a/stl/inc/utility +++ b/stl/inc/utility @@ -198,6 +198,13 @@ concept _Tuple_like = _Tuple_like_impl>; template concept _Pair_like = _Tuple_like<_Ty> && tuple_size_v> == 2; + +#ifdef __clang__ // TRANSITION, LLVM-59827 +template +concept _Can_construct_from_pair_like = + _Pair_like<_PairLike> && is_constructible_v<_Ty1, decltype(_STD get<0>(_STD declval<_PairLike>()))> + && is_constructible_v<_Ty2, decltype(_STD get<1>(_STD declval<_PairLike>()))>; +#endif // __clang__ #endif // _HAS_CXX23 #endif // __cpp_lib_concepts @@ -270,17 +277,19 @@ struct pair { // store a pair of values : first(_STD forward(_Right.first)), second(_STD forward(_Right.second)) {} #ifdef __cpp_lib_concepts - // clang-format off +#ifdef __clang__ // TRANSITION, LLVM-59827 + template , int> = 0> +#else // ^^^ workaround / no workaround vvv template <_Pair_like _Other> requires conjunction_v(_STD declval<_Other>()))>, - is_constructible<_Ty2, decltype(_STD get<1>(_STD declval<_Other>()))>> + is_constructible<_Ty2, decltype(_STD get<1>(_STD declval<_Other>()))>> +#endif // __clang__ constexpr explicit(!conjunction_v(_STD declval<_Other>())), _Ty1>, - is_convertible(_STD declval<_Other>())), _Ty2>>) - pair(_Other&& _Right) - noexcept(is_nothrow_constructible_v<_Ty1, decltype(_STD get<0>(_STD declval<_Other>()))> && - is_nothrow_constructible_v<_Ty2, decltype(_STD get<1>(_STD declval<_Other>()))>) // strengthened - : first(_STD get<0>(_STD forward<_Other>(_Right))), second(_STD get<1>(_STD forward<_Other>(_Right))) {} - // clang-format on + is_convertible(_STD declval<_Other>())), _Ty2>>) + pair(_Other&& _Right) noexcept(is_nothrow_constructible_v<_Ty1, decltype(_STD get<0>(_STD declval<_Other>()))>&& + is_nothrow_constructible_v<_Ty2, decltype(_STD get<1>(_STD declval<_Other>()))>) // strengthened + : first(_STD get<0>(_STD forward<_Other>(_Right))), second(_STD get<1>(_STD forward<_Other>(_Right))) { + } #endif // __cpp_lib_concepts #endif // _HAS_CXX23