diff --git a/libcudacxx/include/cuda/std/detail/libcxx/include/__utility/pair.h b/libcudacxx/include/cuda/std/detail/libcxx/include/__utility/pair.h index ec110ef2857..dd412bb9eec 100644 --- a/libcudacxx/include/cuda/std/detail/libcxx/include/__utility/pair.h +++ b/libcudacxx/include/cuda/std/detail/libcxx/include/__utility/pair.h @@ -11,16 +11,17 @@ #define _LIBCUDACXX___UTILITY_PAIR_H #ifndef __cuda_std__ -#include <__config> +# include <__config> #endif // __cuda_std__ #ifndef _LIBCUDACXX_HAS_NO_SPACESHIP_OPERATOR -#include "../__compare/common_comparison_category.h" -#include "../__compare/synth_three_way.h" +# include "../__compare/common_comparison_category.h" +# include "../__compare/synth_three_way.h" #endif // _LIBCUDACXX_HAS_NO_SPACESHIP_OPERATOR #include "../__functional/unwrap_ref.h" #include "../__fwd/get.h" +#include "../__fwd/pair.h" #include "../__fwd/tuple.h" #include "../__tuple_dir/sfinae_helpers.h" #include "../__tuple_dir/structured_bindings.h" @@ -56,7 +57,7 @@ // Provide compatability between `std::pair` and `cuda::std::pair` #if defined(__cuda_std__) && !defined(__CUDACC_RTC__) -#include +# include #endif // defined(__cuda_std__) && !defined(__CUDACC_RTC__) #if defined(_CCCL_IMPLICIT_SYSTEM_HEADER_GCC) @@ -69,694 +70,708 @@ _LIBCUDACXX_BEGIN_NAMESPACE_STD -template -struct _LIBCUDACXX_TEMPLATE_VIS pair -{ - typedef _T1 first_type; - typedef _T2 second_type; - - _T1 first; - _T2 second; - - pair(pair const&) = default; - pair(pair&&) = default; - - struct _CheckArgs { - struct __enable_implicit_default : public integral_constant::value - && __is_implicitly_default_constructible<_T2>::value> - {}; - - struct __enable_explicit_default : public integral_constant::value - && is_default_constructible<_T2>::value - && !__enable_implicit_default::value> - {}; - - template - struct __is_pair_constructible : public integral_constant::value - && is_constructible::value> - {}; - - template - struct __is_implicit : public integral_constant::value - && is_convertible<_U2, second_type>::value> - {}; - - template - struct __enable_explicit : public integral_constant::value - && !__is_implicit<_U1, _U2>::value> - {}; - - template - struct __enable_implicit : public integral_constant::value - && __is_implicit<_U1, _U2>::value> - {}; - }; - - template - using _CheckArgsDep _LIBCUDACXX_NODEBUG_TYPE = __conditional_t< - _MaybeEnable, _CheckArgs, __check_tuple_constructor_fail>; - - struct _CheckTupleLikeConstructor { - template - struct __enable_implicit : public integral_constant::value> - {}; - template - struct __enable_explicit : public integral_constant::value - && !__tuple_convertible<_Tuple, pair>::value> - {}; - template - struct __enable_assign : public integral_constant::value> - {}; - }; - - template - using _CheckTLC _LIBCUDACXX_NODEBUG_TYPE = __conditional_t< - __tuple_like_with_size<_Tuple, 2>::value - && !is_same<__decay_t<_Tuple>, pair>::value, - _CheckTupleLikeConstructor, - __check_tuple_constructor_fail - >; - - template::__enable_explicit_default::value - >* = nullptr> - explicit _LIBCUDACXX_INLINE_VISIBILITY constexpr - pair() noexcept(is_nothrow_default_constructible::value && - is_nothrow_default_constructible::value) - : first(), second() {} - - template::__enable_implicit_default::value - >* = nullptr> - _LIBCUDACXX_INLINE_VISIBILITY constexpr - pair() noexcept(is_nothrow_default_constructible::value && - is_nothrow_default_constructible::value) - : first(), second() {} - - template ::template __enable_explicit<__make_const_lvalue_ref<_T1>, __make_const_lvalue_ref<_T2>>::value - >* = nullptr> - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 - explicit pair(_T1 const& __t1, _T2 const& __t2) - noexcept(is_nothrow_copy_constructible::value && - is_nothrow_copy_constructible::value) - : first(__t1), second(__t2) {} - - template::template __enable_implicit<__make_const_lvalue_ref<_T1>, __make_const_lvalue_ref<_T2>>::value - >* = nullptr> - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 - pair(_T1 const& __t1, _T2 const& __t2) - noexcept(is_nothrow_copy_constructible::value && - is_nothrow_copy_constructible::value) - : first(__t1), second(__t2) {} - - template < -#if _CCCL_STD_VER > 2020 // http://wg21.link/P1951 - class _U1 = _T1, class _U2 = _T2, -#else - class _U1, class _U2, -#endif - __enable_if_t<_CheckArgs::template __enable_explicit<_U1, _U2>::value>* = nullptr - > - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 - explicit pair(_U1&& __u1, _U2&& __u2) - noexcept((is_nothrow_constructible::value && - is_nothrow_constructible::value)) - : first(_CUDA_VSTD::forward<_U1>(__u1)), second(_CUDA_VSTD::forward<_U2>(__u2)) {} - - template < -#if _CCCL_STD_VER > 2020 // http://wg21.link/P1951 - class _U1 = _T1, class _U2 = _T2, -#else - class _U1, class _U2, -#endif - __enable_if_t<_CheckArgs::template __enable_implicit<_U1, _U2>::value>* = nullptr - > - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 - pair(_U1&& __u1, _U2&& __u2) - noexcept((is_nothrow_constructible::value && - is_nothrow_constructible::value)) - : first(_CUDA_VSTD::forward<_U1>(__u1)), second(_CUDA_VSTD::forward<_U2>(__u2)) {} - -#if _CCCL_STD_VER > 2020 - template::value - >* = nullptr> - _LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_INLINE_VISIBILITY constexpr - explicit(!_CheckArgs::template __is_implicit<_U1&, _U2&>()) pair(pair<_U1, _U2>& __p) - noexcept((is_nothrow_constructible::value && - is_nothrow_constructible::value)) - : first(__p.first), second(__p.second) {} - -#if defined(__cuda_std__) && !defined(__CUDACC_RTC__) - template::value - >* = nullptr> - _LIBCUDACXX_HOST _LIBCUDACXX_INLINE_VISIBILITY constexpr - explicit(!_CheckArgs::template __is_implicit<_U1&, _U2&>()) pair(::std::pair<_U1, _U2>& __p) - noexcept((is_nothrow_constructible::value && - is_nothrow_constructible::value)) - : first(__p.first), second(__p.second) {} -#endif // defined(__cuda_std__) && !defined(__CUDACC_RTC__) -#endif // _CCCL_STD_VER > 2020 - - template::value - >* = nullptr> - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 - explicit pair(pair<_U1, _U2> const& __p) - noexcept((is_nothrow_constructible::value && - is_nothrow_constructible::value)) - : first(__p.first), second(__p.second) {} - -#if defined(__cuda_std__) && !defined(__CUDACC_RTC__) - template::value - >* = nullptr> - _LIBCUDACXX_HOST _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 - explicit pair(::std::pair<_U1, _U2> const& __p) - noexcept((is_nothrow_constructible::value && - is_nothrow_constructible::value)) - : first(__p.first), second(__p.second) {} -#endif // defined(__cuda_std__) && !defined(__CUDACC_RTC__) - - template::value - >* = nullptr> - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 - pair(pair<_U1, _U2> const& __p) - noexcept((is_nothrow_constructible::value && - is_nothrow_constructible::value)) - : first(__p.first), second(__p.second) {} - -#if defined(__cuda_std__) && !defined(__CUDACC_RTC__) - template::value - >* = nullptr> - _LIBCUDACXX_HOST _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 - pair(::std::pair<_U1, _U2> const& __p) - noexcept((is_nothrow_constructible::value && - is_nothrow_constructible::value)) - : first(__p.first), second(__p.second) {} -#endif // defined(__cuda_std__) && !defined(__CUDACC_RTC__) - - template::value - >* = nullptr> - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 - explicit pair(pair<_U1, _U2>&&__p) - noexcept((is_nothrow_constructible::value && - is_nothrow_constructible::value)) - : first(_CUDA_VSTD::forward<_U1>(__p.first)), second(_CUDA_VSTD::forward<_U2>(__p.second)) {} - -#if defined(__cuda_std__) && !defined(__CUDACC_RTC__) - template::value - >* = nullptr> - _LIBCUDACXX_HOST _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 - explicit pair(::std::pair<_U1, _U2>&&__p) - noexcept((is_nothrow_constructible::value && - is_nothrow_constructible::value)) - : first(_CUDA_VSTD::forward<_U1>(__p.first)), second(_CUDA_VSTD::forward<_U2>(__p.second)) {} -#endif // defined(__cuda_std__) && !defined(__CUDACC_RTC__) - - template::value - >* = nullptr> - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 - pair(pair<_U1, _U2>&& __p) - noexcept((is_nothrow_constructible::value && - is_nothrow_constructible::value)) - : first(_CUDA_VSTD::forward<_U1>(__p.first)), second(_CUDA_VSTD::forward<_U2>(__p.second)) {} - -#if defined(__cuda_std__) && !defined(__CUDACC_RTC__) - template::value - >* = nullptr> - _LIBCUDACXX_HOST _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 - pair(::std::pair<_U1, _U2>&& __p) - noexcept((is_nothrow_constructible::value && - is_nothrow_constructible::value)) - : first(_CUDA_VSTD::forward<_U1>(__p.first)), second(_CUDA_VSTD::forward<_U2>(__p.second)) {} -#endif // defined(__cuda_std__) && !defined(__CUDACC_RTC__) - -#if _CCCL_STD_VER > 2020 - template::value - >* = nullptr> - _LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_INLINE_VISIBILITY constexpr - explicit(!_CheckArgs::template __is_implicit::value) - pair(const pair<_U1, _U2>&& __p) - noexcept(is_nothrow_constructible::value && - is_nothrow_constructible::value) - : first(_CUDA_VSTD::move(__p.first)), second(_CUDA_VSTD::move(__p.second)) {} +struct __invalid_pair_constraints +{ + static constexpr bool __implicit_constructible = false; + static constexpr bool __explicit_constructible = false; + static constexpr bool __enable_assign = false; +}; -#if defined(__cuda_std__) && !defined(__CUDACC_RTC__) - template::value - >* = nullptr> - _LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_HOST constexpr - explicit(!_CheckArgs::template __is_implicit::value) - pair(const ::std::pair<_U1, _U2>&& __p) - noexcept(is_nothrow_constructible::value && - is_nothrow_constructible::value) - : first(_CUDA_VSTD::move(__p.first)), second(_CUDA_VSTD::move(__p.second)) {} -#endif // defined(__cuda_std__) && !defined(__CUDACC_RTC__) -#endif // _CCCL_STD_VER > 2020 +template +struct __pair_constraints +{ + static constexpr bool __implicit_default_constructible = + __is_implicitly_default_constructible<_T1>::value && __is_implicitly_default_constructible<_T2>::value; + + static constexpr bool __explicit_default_constructible = + !__implicit_default_constructible && _LIBCUDACXX_TRAIT(is_default_constructible, _T1) + && _LIBCUDACXX_TRAIT(is_default_constructible, _T2); + + static constexpr bool __implicit_copy_constructible_from_T = + _LIBCUDACXX_TRAIT(is_copy_constructible, _T1) && _LIBCUDACXX_TRAIT(is_copy_constructible, _T2) + && _LIBCUDACXX_TRAIT(is_convertible, __make_const_lvalue_ref<_T1>, _T1) + && _LIBCUDACXX_TRAIT(is_convertible, __make_const_lvalue_ref<_T2>, _T2); + + static constexpr bool __explicit_copy_constructible_from_T = + _LIBCUDACXX_TRAIT(is_copy_constructible, _T1) && _LIBCUDACXX_TRAIT(is_copy_constructible, _T2) + && (!_LIBCUDACXX_TRAIT(is_convertible, __make_const_lvalue_ref<_T1>, _T1) + || !_LIBCUDACXX_TRAIT(is_convertible, __make_const_lvalue_ref<_T2>, _T2)); + + static constexpr bool __implicit_move_constructible_from_T = + _LIBCUDACXX_TRAIT(is_move_constructible, _T1) && _LIBCUDACXX_TRAIT(is_move_constructible, _T2) + && _LIBCUDACXX_TRAIT(is_convertible, __make_const_lvalue_ref<_T1>, _T1) + && _LIBCUDACXX_TRAIT(is_convertible, __make_const_lvalue_ref<_T2>, _T2); + + static constexpr bool __explicit_move_constructible_from_T = + _LIBCUDACXX_TRAIT(is_move_constructible, _T1) && _LIBCUDACXX_TRAIT(is_move_constructible, _T2) + && (!_LIBCUDACXX_TRAIT(is_convertible, _T1, _T1) || !_LIBCUDACXX_TRAIT(is_convertible, _T2, _T2)); + + template + struct __constructible + { + static constexpr bool __implicit_constructible = + _LIBCUDACXX_TRAIT(is_constructible, _T1, _U1) && _LIBCUDACXX_TRAIT(is_constructible, _T2, _U2) + && _LIBCUDACXX_TRAIT(is_convertible, _U1, _T1) && _LIBCUDACXX_TRAIT(is_convertible, _U2, _T2); + + static constexpr bool __explicit_constructible = + _LIBCUDACXX_TRAIT(is_constructible, _T1, _U1) && _LIBCUDACXX_TRAIT(is_constructible, _T2, _U2) + && (!_LIBCUDACXX_TRAIT(is_convertible, _U1, _T1) || !_LIBCUDACXX_TRAIT(is_convertible, _U2, _T2)); + }; + + template + struct __assignable + { + static constexpr bool __enable_assign = + _LIBCUDACXX_TRAIT(is_assignable, _T1&, _U1) && _LIBCUDACXX_TRAIT(is_assignable, _T2&, _U2); + }; +}; - template::template __enable_explicit<_Tuple>::value - >* = nullptr> - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 - explicit pair(_Tuple&& __p) - : first(_CUDA_VSTD::get<0>(_CUDA_VSTD::forward<_Tuple>(__p))), - second(_CUDA_VSTD::get<1>(_CUDA_VSTD::forward<_Tuple>(__p))) {} - - template::template __enable_implicit<_Tuple>::value - >* = nullptr> - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 - pair(_Tuple&& __p) - : first(_CUDA_VSTD::get<0>(_CUDA_VSTD::forward<_Tuple>(__p))), - second(_CUDA_VSTD::get<1>(_CUDA_VSTD::forward<_Tuple>(__p))) {} - - template - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX17 - pair(piecewise_construct_t __pc, - tuple<_Args1...> __first_args, tuple<_Args2...> __second_args) - noexcept((is_nothrow_constructible::value && - is_nothrow_constructible::value)) - : pair(__pc, __first_args, __second_args, - __make_tuple_indices_t(), - __make_tuple_indices_t()) {} - - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX17 - pair& operator=(__conditional_t< - is_copy_assignable::value && - is_copy_assignable::value, - pair, __nat> const& __p) - noexcept(is_nothrow_copy_assignable::value && - is_nothrow_copy_assignable::value) - { - first = __p.first; - second = __p.second; - return *this; - } +// We need to synthesize the copy / move assignment if it would be implicitly deleted as a member of a class +// In that case _T1 would be copy assignable but _TestSynthesizeAssignment<_T1> would not +// This happens e.g for reference types +template +struct _TestSynthesizeAssignment +{ + _T1 __dummy; +}; -#if defined(__cuda_std__) && !defined(__CUDACC_RTC__) - template::value && - is_copy_assignable<_T2>::value, int> = 0> - _LIBCUDACXX_HOST _LIBCUDACXX_CONSTEXPR_AFTER_CXX17 - pair& operator=(::std::pair<_T1, _T2> const& __p) - noexcept(is_nothrow_copy_assignable::value && - is_nothrow_copy_assignable::value) - { - first = __p.first; - second = __p.second; - return *this; - } -#endif // defined(__cuda_std__) && !defined(__CUDACC_RTC__) +template +struct __must_synthesize_assignment + : integral_constant) + && _LIBCUDACXX_TRAIT(is_copy_assignable, _TestSynthesizeAssignment<_T2>))) + || (_LIBCUDACXX_TRAIT(is_copy_assignable, _T1) && _LIBCUDACXX_TRAIT(is_copy_assignable, _T2) + && !(_LIBCUDACXX_TRAIT(is_copy_assignable, _TestSynthesizeAssignment<_T1>) + && _LIBCUDACXX_TRAIT(is_copy_assignable, _TestSynthesizeAssignment<_T2>)))> +{}; + +// base class to ensure `is_trivially_copyable` when possible +template ::value> +struct __pair_base +{ + _T1 first; + _T2 second; + + template , + __enable_if_t<_Constraints::__implicit_default_constructible, int> = 0> + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_HIDE_FROM_ABI constexpr __pair_base() noexcept( + _LIBCUDACXX_TRAIT(is_nothrow_default_constructible, _T1) + && _LIBCUDACXX_TRAIT(is_nothrow_default_constructible, _T2)) + : first() + , second() + {} + + template , + __enable_if_t<_Constraints::__explicit_default_constructible, int> = 0> + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_HIDE_FROM_ABI explicit constexpr __pair_base() noexcept( + _LIBCUDACXX_TRAIT(is_nothrow_default_constructible, _T1) + && _LIBCUDACXX_TRAIT(is_nothrow_default_constructible, _T2)) + : first() + , second() + {} + + template + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_HIDE_FROM_ABI constexpr __pair_base(_U1&& __t1, _U2&& __t2) noexcept( + _LIBCUDACXX_TRAIT(is_nothrow_constructible, _T1, _U1) && _LIBCUDACXX_TRAIT(is_nothrow_constructible, _T2, _U2)) + : first(_CUDA_VSTD::forward<_U1>(__t1)) + , second(_CUDA_VSTD::forward<_U2>(__t2)) + {} + +protected: + template + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX17 __pair_base( + piecewise_construct_t, + tuple<_Args1...>& __first_args, + tuple<_Args2...>& __second_args, + __tuple_indices<_I1...>, + __tuple_indices<_I2...>); +}; - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX17 - pair& operator=(__conditional_t< - is_move_assignable::value && - is_move_assignable::value, - pair, __nat>&& __p) - noexcept(is_nothrow_move_assignable::value && - is_nothrow_move_assignable::value) - { - first = _CUDA_VSTD::forward(__p.first); - second = _CUDA_VSTD::forward(__p.second); - return *this; - } +// We need to ensure that a reference type, which would inhibit the implicit copy assignment still works +template +struct __pair_base<_T1, _T2, true> +{ + _T1 first; + _T2 second; + + template , + __enable_if_t<_Constraints::__implicit_default_constructible, int> = 0> + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_HIDE_FROM_ABI constexpr __pair_base() noexcept( + _LIBCUDACXX_TRAIT(is_nothrow_default_constructible, _T1) + && _LIBCUDACXX_TRAIT(is_nothrow_default_constructible, _T2)) + : first() + , second() + {} + + template , + __enable_if_t<_Constraints::__explicit_default_constructible, int> = 0> + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_HIDE_FROM_ABI explicit constexpr __pair_base() noexcept( + _LIBCUDACXX_TRAIT(is_nothrow_default_constructible, _T1) + && _LIBCUDACXX_TRAIT(is_nothrow_default_constructible, _T2)) + : first() + , second() + {} + + constexpr __pair_base(const __pair_base&) = default; + constexpr __pair_base(__pair_base&&) = default; + + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 __pair_base& operator=( + __conditional_t<_LIBCUDACXX_TRAIT(is_copy_assignable, _T1) && _LIBCUDACXX_TRAIT(is_copy_assignable, _T2), + __pair_base, + __nat> const& __p) noexcept(_LIBCUDACXX_TRAIT(is_nothrow_move_assignable, _T1) + && _LIBCUDACXX_TRAIT(is_nothrow_move_assignable, _T2)) + { + first = __p.first; + second = __p.second; + return *this; + } + + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 __pair_base& operator=( + __conditional_t<_LIBCUDACXX_TRAIT(is_move_assignable, _T1) && _LIBCUDACXX_TRAIT(is_move_assignable, _T2), + __pair_base, + __nat>&& __p) noexcept(_LIBCUDACXX_TRAIT(is_nothrow_move_assignable, _T1) + && _LIBCUDACXX_TRAIT(is_nothrow_move_assignable, _T2)) + { + first = _CUDA_VSTD::forward<_T1>(__p.first); + second = _CUDA_VSTD::forward<_T2>(__p.second); + return *this; + } + + template + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_HIDE_FROM_ABI constexpr __pair_base(_U1&& __t1, _U2&& __t2) noexcept( + _LIBCUDACXX_TRAIT(is_nothrow_constructible, _T1, _U1) && _LIBCUDACXX_TRAIT(is_nothrow_constructible, _T2, _U2)) + : first(_CUDA_VSTD::forward<_U1>(__t1)) + , second(_CUDA_VSTD::forward<_U2>(__t2)) + {} + +protected: + template + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX17 __pair_base( + piecewise_construct_t, + tuple<_Args1...>& __first_args, + tuple<_Args2...>& __second_args, + __tuple_indices<_I1...>, + __tuple_indices<_I2...>); +}; +template +struct _LIBCUDACXX_TEMPLATE_VIS pair : public __pair_base<_T1, _T2> +{ + using __base = __pair_base<_T1, _T2>; + + typedef _T1 first_type; + typedef _T2 second_type; + + template , + __enable_if_t<_Constraints::__implicit_default_constructible, int> = 0> + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_HIDE_FROM_ABI constexpr pair() noexcept( + _LIBCUDACXX_TRAIT(is_nothrow_default_constructible, _T1) + && _LIBCUDACXX_TRAIT(is_nothrow_default_constructible, _T2)) + : __base() + {} + + template , + __enable_if_t<_Constraints::__explicit_default_constructible, int> = 0> + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_HIDE_FROM_ABI explicit constexpr pair() noexcept( + _LIBCUDACXX_TRAIT(is_nothrow_default_constructible, _T1) + && _LIBCUDACXX_TRAIT(is_nothrow_default_constructible, _T2)) + : __base() + {} + + // element wise constructors + template , + __enable_if_t<_Constraints::__explicit_copy_constructible_from_T, int> = 0> + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_HIDE_FROM_ABI explicit constexpr pair( + const _T1& __t1, const _T2& __t2) noexcept(_LIBCUDACXX_TRAIT(is_nothrow_copy_constructible, _T1) + && _LIBCUDACXX_TRAIT(is_nothrow_copy_constructible, _T2)) + : __base(__t1, __t2) + {} + + template , + __enable_if_t<_Constraints::__implicit_copy_constructible_from_T, int> = 0> + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_HIDE_FROM_ABI constexpr pair(const _T1& __t1, const _T2& __t2) noexcept( + _LIBCUDACXX_TRAIT(is_nothrow_copy_constructible, _T1) && _LIBCUDACXX_TRAIT(is_nothrow_copy_constructible, _T2)) + : __base(__t1, __t2) + {} + + template ::template __constructible<_U1, _U2>, + __enable_if_t<_Constraints::__explicit_constructible, int> = 0> + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_HIDE_FROM_ABI explicit constexpr pair(_U1&& __u1, _U2&& __u2) noexcept( + _LIBCUDACXX_TRAIT(is_nothrow_constructible, _T1, _U1) && _LIBCUDACXX_TRAIT(is_nothrow_constructible, _T2, _U2)) + : __base(_CUDA_VSTD::forward<_U1>(__u1), _CUDA_VSTD::forward<_U2>(__u2)) + {} + + template ::template __constructible<_U1, _U2>, + __enable_if_t<_Constraints::__implicit_constructible, int> = 0> + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_HIDE_FROM_ABI constexpr pair(_U1&& __u1, _U2&& __u2) noexcept( + _LIBCUDACXX_TRAIT(is_nothrow_constructible, _T1, _U1) && _LIBCUDACXX_TRAIT(is_nothrow_constructible, _T2, _U2)) + : __base(_CUDA_VSTD::forward<_U1>(__u1), _CUDA_VSTD::forward<_U2>(__u2)) + {} + + template + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX17 + pair(piecewise_construct_t __pc, tuple<_Args1...> __first_args, tuple<_Args2...> __second_args) noexcept( + (is_nothrow_constructible::value && is_nothrow_constructible::value)) + : __base(__pc, + __first_args, + __second_args, + __make_tuple_indices_t(), + __make_tuple_indices_t()) + {} + + // copy constructors + pair(pair const&) = default; + pair(pair&&) = default; + + template ::template __constructible, + __enable_if_t<_Constraints::__explicit_constructible, int> = 0> + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_HIDE_FROM_ABI explicit _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 + pair(const pair<_U1, _U2>& __p) noexcept(_LIBCUDACXX_TRAIT(is_nothrow_constructible, _T1, const _U1&) + && _LIBCUDACXX_TRAIT(is_nothrow_constructible, _T2, const _U2&)) + : __base(__p.first, __p.second) + {} + + template ::template __constructible, + __enable_if_t<_Constraints::__implicit_constructible, int> = 0> + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 + pair(const pair<_U1, _U2>& __p) noexcept(_LIBCUDACXX_TRAIT(is_nothrow_constructible, _T1, const _U1&) + && _LIBCUDACXX_TRAIT(is_nothrow_constructible, _T2, const _U2&)) + : __base(__p.first, __p.second) + {} + + // move constructors + template ::template __constructible<_U1, _U2>, + __enable_if_t<_Constraints::__explicit_constructible, int> = 0> + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_HIDE_FROM_ABI explicit _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 + pair(pair<_U1, _U2>&& __p) noexcept(_LIBCUDACXX_TRAIT(is_nothrow_constructible, _T1, _U1) + && _LIBCUDACXX_TRAIT(is_nothrow_constructible, _T2, _U2)) + : __base(_CUDA_VSTD::forward<_U1>(__p.first), _CUDA_VSTD::forward<_U2>(__p.second)) + {} + + template ::template __constructible<_U1, _U2>, + __enable_if_t<_Constraints::__implicit_constructible, int> = 0> + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 + pair(pair<_U1, _U2>&& __p) noexcept(_LIBCUDACXX_TRAIT(is_nothrow_constructible, _T1, _U1) + && _LIBCUDACXX_TRAIT(is_nothrow_constructible, _T2, _U2)) + : __base(_CUDA_VSTD::forward<_U1>(__p.first), _CUDA_VSTD::forward<_U2>(__p.second)) + {} + + // std compatability +#if defined(__cuda_std__) && !defined(_CCCL_COMPILER_NVRTC) + template ::template __constructible, + __enable_if_t<_Constraints::__explicit_constructible, int> = 0> + _LIBCUDACXX_HOST _LIBCUDACXX_HIDE_FROM_ABI explicit _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 + pair(const ::std::pair<_U1, _U2>& __p) noexcept(_LIBCUDACXX_TRAIT(is_nothrow_constructible, _T1, const _U1&) + && _LIBCUDACXX_TRAIT(is_nothrow_constructible, _T2, const _U2&)) + : __base(__p.first, __p.second) + {} + + template ::template __constructible, + __enable_if_t<_Constraints::__implicit_constructible, int> = 0> + _LIBCUDACXX_HOST _LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 + pair(const ::std::pair<_U1, _U2>& __p) noexcept(_LIBCUDACXX_TRAIT(is_nothrow_constructible, _T1, const _U1&) + && _LIBCUDACXX_TRAIT(is_nothrow_constructible, _T2, const _U2&)) + : __base(__p.first, __p.second) + {} + + template ::template __constructible<_U1, _U2>, + __enable_if_t<_Constraints::__explicit_constructible, int> = 0> + _LIBCUDACXX_HOST _LIBCUDACXX_HIDE_FROM_ABI explicit _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 + pair(::std::pair<_U1, _U2>&& __p) noexcept(_LIBCUDACXX_TRAIT(is_nothrow_constructible, _T1, _U1) + && _LIBCUDACXX_TRAIT(is_nothrow_constructible, _T2, _U2)) + : __base(_CUDA_VSTD::forward<_U1>(__p.first), _CUDA_VSTD::forward<_U2>(__p.second)) + {} + + template ::template __constructible<_U1, _U2>, + __enable_if_t<_Constraints::__implicit_constructible, int> = 0> + _LIBCUDACXX_HOST _LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 + pair(::std::pair<_U1, _U2>&& __p) noexcept(_LIBCUDACXX_TRAIT(is_nothrow_constructible, _T1, _U1) + && _LIBCUDACXX_TRAIT(is_nothrow_constructible, _T2, _U2)) + : __base(_CUDA_VSTD::forward<_U1>(__p.first), _CUDA_VSTD::forward<_U2>(__p.second)) + {} +#endif // defined(__cuda_std__) && !defined(_CCCL_COMPILER_NVRTC) + + // assignments + pair& operator=(const pair&) = default; + pair& operator=(pair&&) = default; + + template ::template __assignable, + __enable_if_t<_Constraints::__enable_assign, int> = 0> + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 pair& operator=(const pair<_U1, _U2>& __p) noexcept( + _LIBCUDACXX_TRAIT(is_nothrow_assignable, _T1, const _U1&) + && _LIBCUDACXX_TRAIT(is_nothrow_assignable, _T2, const _U2&)) + { + this->first = __p.first; + this->second = __p.second; + return *this; + } + + template ::template __assignable<_U1, _U2>, + __enable_if_t<_Constraints::__enable_assign, int> = 0> + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 pair& operator=(pair<_U1, _U2>&& __p) noexcept( + _LIBCUDACXX_TRAIT(is_nothrow_assignable, _T1, _U1&&) && _LIBCUDACXX_TRAIT(is_nothrow_assignable, _T2, _U2&&)) + { + this->first = _CUDA_VSTD::forward<_U1>(__p.first); + this->second = _CUDA_VSTD::forward<_U2>(__p.second); + return *this; + } + + // std assignments #if defined(__cuda_std__) && !defined(__CUDACC_RTC__) - template::value && - is_move_assignable<_T2>::value, int> = 0> - _LIBCUDACXX_HOST _LIBCUDACXX_CONSTEXPR_AFTER_CXX17 - pair& operator=(::std::pair<_T1, _T2>&& __p) - noexcept(is_nothrow_move_assignable::value && - is_nothrow_move_assignable::value) - { - first = _CUDA_VSTD::forward(__p.first); - second = _CUDA_VSTD::forward(__p.second); - return *this; - } + template ::value && is_copy_assignable<_T2>::value, int> = 0> + _LIBCUDACXX_HOST _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 pair& operator=(::std::pair<_T1, _T2> const& __p) noexcept( + _LIBCUDACXX_TRAIT(is_nothrow_copy_assignable, _T1) && _LIBCUDACXX_TRAIT(is_nothrow_copy_assignable, _T2)) + { + this->first = __p.first; + this->second = __p.second; + return *this; + } + + template ::value && is_move_assignable<_T2>::value, int> = 0> + _LIBCUDACXX_HOST _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 pair& operator=(::std::pair<_T1, _T2>&& __p) noexcept( + _LIBCUDACXX_TRAIT(is_nothrow_copy_assignable, _T1) && _LIBCUDACXX_TRAIT(is_nothrow_copy_assignable, _T2)) + { + this->first = _CUDA_VSTD::forward<_T1>(__p.first); + this->second = _CUDA_VSTD::forward<_T2>(__p.second); + return *this; + } #endif // defined(__cuda_std__) && !defined(__CUDACC_RTC__) #if _CCCL_STD_VER > 2020 - _LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_INLINE_VISIBILITY constexpr - const pair& operator=(pair const& __p) const - noexcept(is_nothrow_copy_assignable_v && - is_nothrow_copy_assignable_v) - requires(is_copy_assignable_v && - is_copy_assignable_v) { - first = __p.first; - second = __p.second; - return *this; - } - -#if defined(__cuda_std__) && !defined(__CUDACC_RTC__) - _LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_HOST constexpr - const pair& operator=(::std::pair<_T1, _T2> const& __p) const - noexcept(is_nothrow_copy_assignable_v && - is_nothrow_copy_assignable_v) - requires(is_copy_assignable_v && - is_copy_assignable_v) { - first = __p.first; - second = __p.second; - return *this; - } -#endif // defined(__cuda_std__) && !defined(__CUDACC_RTC__) - - _LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_INLINE_VISIBILITY constexpr - const pair& operator=(pair&& __p) const - noexcept(is_nothrow_assignable_v && - is_nothrow_assignable_v) - requires(is_assignable_v && - is_assignable_v) { - first = _CUDA_VSTD::forward(__p.first); - second = _CUDA_VSTD::forward(__p.second); - return *this; - } - -#if defined(__cuda_std__) && !defined(__CUDACC_RTC__) - _LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_HOST constexpr - const pair& operator=(::std::pair<_T1, _T2>&& __p) const - noexcept(is_nothrow_assignable_v && - is_nothrow_assignable_v) - requires(is_assignable_v && - is_assignable_v) { - first = _CUDA_VSTD::forward(__p.first); - second = _CUDA_VSTD::forward(__p.second); - return *this; - } -#endif // defined(__cuda_std__) && !defined(__CUDACC_RTC__) - - template - _LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_INLINE_VISIBILITY constexpr - const pair& operator=(const pair<_U1, _U2>& __p) const - requires(is_assignable_v && - is_assignable_v) { - first = __p.first; - second = __p.second; - return *this; - } - -#if defined(__cuda_std__) && !defined(__CUDACC_RTC__) - template - _LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_HOST constexpr - const pair& operator=(const ::std::pair<_U1, _U2>& __p) const - requires(is_assignable_v && - is_assignable_v) { - first = __p.first; - second = __p.second; - return *this; - } -#endif // defined(__cuda_std__) && !defined(__CUDACC_RTC__) - - template - _LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_INLINE_VISIBILITY constexpr - const pair& operator=(pair<_U1, _U2>&& __p) const - requires(is_assignable_v && - is_assignable_v) { - first = _CUDA_VSTD::forward<_U1>(__p.first); - second = _CUDA_VSTD::forward<_U2>(__p.second); - return *this; - } - -#if defined(__cuda_std__) && !defined(__CUDACC_RTC__) - template - _LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_HOST constexpr - const pair& operator=(::std::pair<_U1, _U2>&& __p) const - requires(is_assignable_v && - is_assignable_v) { - first = _CUDA_VSTD::forward<_U1>(__p.first); - second = _CUDA_VSTD::forward<_U2>(__p.second); - return *this; - } -#endif // defined(__cuda_std__) && !defined(__CUDACC_RTC__) + _LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_INLINE_VISIBILITY constexpr const pair& operator=(pair const& __p) const + noexcept(_LIBCUDACXX_TRAIT(is_nothrow_copy_assignable, const _T1) + && _LIBCUDACXX_TRAIT(is_nothrow_copy_assignable, const _T2)) + requires(is_copy_assignable_v && is_copy_assignable_v) + { + this->first = __p.first; + this->second = __p.second; + return *this; + } + +# if defined(__cuda_std__) && !defined(__CUDACC_RTC__) + _LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_HOST constexpr const pair& operator=(::std::pair<_T1, _T2> const& __p) const + noexcept(_LIBCUDACXX_TRAIT(is_nothrow_copy_assignable, const _T1) + && _LIBCUDACXX_TRAIT(is_nothrow_copy_assignable, const _T2)) + requires(is_copy_assignable_v && is_copy_assignable_v) + { + this->first = __p.first; + this->second = __p.second; + return *this; + } +# endif // defined(__cuda_std__) && !defined(__CUDACC_RTC__) + + _LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_INLINE_VISIBILITY constexpr const pair& operator=(pair&& __p) const + noexcept(_LIBCUDACXX_TRAIT(is_nothrow_assignable, const _T1&, _T1) + && _LIBCUDACXX_TRAIT(is_nothrow_assignable, const _T2&, _T2)) + requires(is_assignable_v && is_assignable_v) + { + this->first = _CUDA_VSTD::forward(__p.first); + this->second = _CUDA_VSTD::forward(__p.second); + return *this; + } + +# if defined(__cuda_std__) && !defined(__CUDACC_RTC__) + _LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_HOST constexpr const pair& operator=(::std::pair<_T1, _T2>&& __p) const + noexcept(_LIBCUDACXX_TRAIT(is_nothrow_assignable, const _T1&, _T1) + && _LIBCUDACXX_TRAIT(is_nothrow_assignable, const _T2&, _T2)) + requires(is_assignable_v && is_assignable_v) + { + this->first = _CUDA_VSTD::forward(__p.first); + this->second = _CUDA_VSTD::forward(__p.second); + return *this; + } +# endif // defined(__cuda_std__) && !defined(__CUDACC_RTC__) + + template + _LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_INLINE_VISIBILITY constexpr const pair& + operator=(const pair<_U1, _U2>& __p) const + requires(is_assignable_v && is_assignable_v) + { + this->first = __p.first; + this->second = __p.second; + return *this; + } + +# if defined(__cuda_std__) && !defined(__CUDACC_RTC__) + template + _LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_HOST constexpr const pair& operator=(const ::std::pair<_U1, _U2>& __p) const + requires(is_assignable_v && is_assignable_v) + { + this->first = __p.first; + this->second = __p.second; + return *this; + } +# endif // defined(__cuda_std__) && !defined(__CUDACC_RTC__) + + template + _LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_INLINE_VISIBILITY constexpr const pair& operator=(pair<_U1, _U2>&& __p) const + requires(is_assignable_v && is_assignable_v) + { + this->first = _CUDA_VSTD::forward<_U1>(__p.first); + this->second = _CUDA_VSTD::forward<_U2>(__p.second); + return *this; + } + +# if defined(__cuda_std__) && !defined(__CUDACC_RTC__) + template + _LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_HOST constexpr const pair& operator=(::std::pair<_U1, _U2>&& __p) const + requires(is_assignable_v && is_assignable_v) + { + this->first = _CUDA_VSTD::forward<_U1>(__p.first); + this->second = _CUDA_VSTD::forward<_U2>(__p.second); + return *this; + } +# endif // defined(__cuda_std__) && !defined(__CUDACC_RTC__) #endif // _CCCL_STD_VER > 2020 - template ::template __enable_assign<_Tuple>::value - >* = nullptr> - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX17 - pair& operator=(_Tuple&& __p) { - first = _CUDA_VSTD::get<0>(_CUDA_VSTD::forward<_Tuple>(__p)); - second = _CUDA_VSTD::get<1>(_CUDA_VSTD::forward<_Tuple>(__p)); - return *this; - } - - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX17 - void swap(pair& __p) noexcept(__is_nothrow_swappable::value && - __is_nothrow_swappable::value) - { - using _CUDA_VSTD::swap; - swap(first, __p.first); - swap(second, __p.second); - } + _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX17 void + swap(pair& __p) noexcept(__is_nothrow_swappable::value && __is_nothrow_swappable::value) + { + using _CUDA_VSTD::swap; + swap(this->first, __p.first); + swap(this->second, __p.second); + } #if _CCCL_STD_VER > 2020 - _LIBCUDACXX_HIDE_FROM_ABI constexpr - void swap(const pair& __p) const - noexcept(__is_nothrow_swappable::value && - __is_nothrow_swappable::value) - { - using _CUDA_VSTD::swap; - swap(first, __p.first); - swap(second, __p.second); - } + _LIBCUDACXX_HIDE_FROM_ABI constexpr void swap(const pair& __p) const + noexcept(__is_nothrow_swappable::value && __is_nothrow_swappable::value) + { + using _CUDA_VSTD::swap; + swap(this->first, __p.first); + swap(this->second, __p.second); + } #endif // _CCCL_STD_VER > 2020 #if defined(__cuda_std__) && !defined(__CUDACC_RTC__) - _LIBCUDACXX_HOST _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 - operator ::std::pair<_T1, _T2>() const { return { first, second }; } + _LIBCUDACXX_HOST _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 operator ::std::pair<_T1, _T2>() const + { + return {this->first, this->second}; + } #endif // defined(__cuda_std__) && !defined(__CUDACC_RTC__) - -private: - - template - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX17 - pair(piecewise_construct_t, - tuple<_Args1...>& __first_args, tuple<_Args2...>& __second_args, - __tuple_indices<_I1...>, __tuple_indices<_I2...>); }; #if _CCCL_STD_VER > 2014 && !defined(_LIBCUDACXX_HAS_NO_DEDUCTION_GUIDES) -template +template _LIBCUDACXX_HOST_DEVICE pair(_T1, _T2) -> pair<_T1, _T2>; #endif // _CCCL_STD_VER > 2014 && !defined(_LIBCUDACXX_HAS_NO_DEDUCTION_GUIDES) // [pairs.spec], specialized algorithms template -inline _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 -bool -operator==(const pair<_T1,_T2>& __x, const pair<_T1,_T2>& __y) +inline _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 bool +operator==(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) { - return __x.first == __y.first && __x.second == __y.second; + return __x.first == __y.first && __x.second == __y.second; } #ifndef _LIBCUDACXX_HAS_NO_SPACESHIP_OPERATOR template -_LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_INLINE_VISIBILITY constexpr -common_comparison_category_t< - __synth_three_way_result<_T1>, - __synth_three_way_result<_T2> > -operator<=>(const pair<_T1,_T2>& __x, const pair<_T1,_T2>& __y) -{ - if (auto __c = _CUDA_VSTD::__synth_three_way(__x.first, __y.first); __c != 0) { - return __c; - } - return _CUDA_VSTD::__synth_three_way(__x.second, __y.second); +_LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_INLINE_VISIBILITY constexpr common_comparison_category_t< + __synth_three_way_result<_T1>, + __synth_three_way_result<_T2> > +operator<=>(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) +{ + if (auto __c = _CUDA_VSTD::__synth_three_way(__x.first, __y.first); __c != 0) + { + return __c; + } + return _CUDA_VSTD::__synth_three_way(__x.second, __y.second); } #else // _LIBCUDACXX_HAS_NO_SPACESHIP_OPERATOR template -inline _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 -bool -operator!=(const pair<_T1,_T2>& __x, const pair<_T1,_T2>& __y) +inline _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 bool +operator!=(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) { - return !(__x == __y); + return !(__x == __y); } template -inline _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 -bool -operator< (const pair<_T1,_T2>& __x, const pair<_T1,_T2>& __y) +inline _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 bool +operator<(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) { - return __x.first < __y.first || (!(__y.first < __x.first) && __x.second < __y.second); + return __x.first < __y.first || (!(__y.first < __x.first) && __x.second < __y.second); } template -inline _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 -bool -operator> (const pair<_T1,_T2>& __x, const pair<_T1,_T2>& __y) +inline _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 bool +operator>(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) { - return __y < __x; + return __y < __x; } template -inline _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 -bool -operator>=(const pair<_T1,_T2>& __x, const pair<_T1,_T2>& __y) +inline _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 bool +operator>=(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) { - return !(__x < __y); + return !(__x < __y); } template -inline _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 -bool -operator<=(const pair<_T1,_T2>& __x, const pair<_T1,_T2>& __y) +inline _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 bool +operator<=(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) { - return !(__y < __x); + return !(__y < __x); } #endif // _LIBCUDACXX_HAS_NO_SPACESHIP_OPERATOR #if _CCCL_STD_VER > 2017 -template class _TQual, template class _UQual> - requires requires { typename pair, _UQual<_U1>>, - common_reference_t<_TQual<_T2>, _UQual<_U2>>>; } -struct basic_common_reference, pair<_U1, _U2>, _TQual, _UQual> { - using type = pair, _UQual<_U1>>, - common_reference_t<_TQual<_T2>, _UQual<_U2>>>; +template class _TQual, template class _UQual> + requires requires { + typename pair, _UQual<_U1>>, common_reference_t<_TQual<_T2>, _UQual<_U2>>>; + } +struct basic_common_reference, pair<_U1, _U2>, _TQual, _UQual> +{ + using type = pair, _UQual<_U1>>, common_reference_t<_TQual<_T2>, _UQual<_U2>>>; }; template - requires requires { typename pair, common_type_t<_T2, _U2>>; } -struct common_type, pair<_U1, _U2>> { - using type = pair, common_type_t<_T2, _U2>>; + requires requires { typename pair, common_type_t<_T2, _U2>>; } +struct common_type, pair<_U1, _U2>> +{ + using type = pair, common_type_t<_T2, _U2>>; }; #endif // _CCCL_STD_VER > 2017 template -inline _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX17 -__enable_if_t -< - __is_swappable<_T1>::value && - __is_swappable<_T2>::value, - void -> -swap(pair<_T1, _T2>& __x, pair<_T1, _T2>& __y) - noexcept((__is_nothrow_swappable<_T1>::value && - __is_nothrow_swappable<_T2>::value)) -{ - __x.swap(__y); +inline _LIBCUDACXX_INLINE_VISIBILITY + _LIBCUDACXX_CONSTEXPR_AFTER_CXX17 __enable_if_t<__is_swappable<_T1>::value && __is_swappable<_T2>::value, void> + swap(pair<_T1, _T2>& __x, + pair<_T1, _T2>& __y) noexcept((__is_nothrow_swappable<_T1>::value && __is_nothrow_swappable<_T2>::value)) +{ + __x.swap(__y); } #if _CCCL_STD_VER > 2020 template - requires (__is_swappable::value && - __is_swappable::value) -_LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_INLINE_VISIBILITY constexpr -void swap(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) - noexcept(noexcept(__x.swap(__y))) + requires(__is_swappable::value && __is_swappable::value) +_LIBCUDACXX_HIDE_FROM_ABI _LIBCUDACXX_INLINE_VISIBILITY constexpr void +swap(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) noexcept(noexcept(__x.swap(__y))) { - __x.swap(__y); + __x.swap(__y); } #endif // _CCCL_STD_VER > 2020 template inline _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 -pair::type, typename __unwrap_ref_decay<_T2>::type> -make_pair(_T1&& __t1, _T2&& __t2) + pair::type, typename __unwrap_ref_decay<_T2>::type> + make_pair(_T1&& __t1, _T2&& __t2) { - return pair::type, typename __unwrap_ref_decay<_T2>::type> - (_CUDA_VSTD::forward<_T1>(__t1), _CUDA_VSTD::forward<_T2>(__t2)); + return pair::type, typename __unwrap_ref_decay<_T2>::type>( + _CUDA_VSTD::forward<_T1>(__t1), _CUDA_VSTD::forward<_T2>(__t2)); } template - struct _LIBCUDACXX_TEMPLATE_VIS tuple_size > - : public integral_constant {}; +struct _LIBCUDACXX_TEMPLATE_VIS tuple_size > : public integral_constant +{}; template struct _LIBCUDACXX_TEMPLATE_VIS tuple_element<_Ip, pair<_T1, _T2> > { - static_assert(_Ip < 2, "Index out of bounds in std::tuple_element>"); + static_assert(_Ip < 2, "Index out of bounds in std::tuple_element>"); }; template struct _LIBCUDACXX_TEMPLATE_VIS tuple_element<0, pair<_T1, _T2> > { - typedef _LIBCUDACXX_NODEBUG_TYPE _T1 type; + typedef _LIBCUDACXX_NODEBUG_TYPE _T1 type; }; template struct _LIBCUDACXX_TEMPLATE_VIS tuple_element<1, pair<_T1, _T2> > { - typedef _LIBCUDACXX_NODEBUG_TYPE _T2 type; + typedef _LIBCUDACXX_NODEBUG_TYPE _T2 type; }; -template struct __get_pair; +template +struct __get_pair; template <> struct __get_pair<0> { - template - static - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 - _T1& - get(pair<_T1, _T2>& __p) noexcept {return __p.first;} - - template - static - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 - const _T1& - get(const pair<_T1, _T2>& __p) noexcept {return __p.first;} - - template - static - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 - _T1&& - get(pair<_T1, _T2>&& __p) noexcept {return _CUDA_VSTD::forward<_T1>(__p.first);} - - template - static - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 - const _T1&& - get(const pair<_T1, _T2>&& __p) noexcept {return _CUDA_VSTD::forward(__p.first);} + template + static _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 _T1& get(pair<_T1, _T2>& __p) noexcept + { + return __p.first; + } + + template + static _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 const _T1& + get(const pair<_T1, _T2>& __p) noexcept + { + return __p.first; + } + + template + static _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 _T1&& get(pair<_T1, _T2>&& __p) noexcept + { + return _CUDA_VSTD::forward<_T1>(__p.first); + } + + template + static _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 const _T1&& + get(const pair<_T1, _T2>&& __p) noexcept + { + return _CUDA_VSTD::forward(__p.first); + } }; template <> struct __get_pair<1> { - template - static - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 - _T2& - get(pair<_T1, _T2>& __p) noexcept {return __p.second;} - - template - static - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 - const _T2& - get(const pair<_T1, _T2>& __p) noexcept {return __p.second;} - - template - static - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 - _T2&& - get(pair<_T1, _T2>&& __p) noexcept {return _CUDA_VSTD::forward<_T2>(__p.second);} - - template - static - _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 - const _T2&& - get(const pair<_T1, _T2>&& __p) noexcept {return _CUDA_VSTD::forward(__p.second);} + template + static _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 _T2& get(pair<_T1, _T2>& __p) noexcept + { + return __p.second; + } + + template + static _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 const _T2& + get(const pair<_T1, _T2>& __p) noexcept + { + return __p.second; + } + + template + static _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 _T2&& get(pair<_T1, _T2>&& __p) noexcept + { + return _CUDA_VSTD::forward<_T2>(__p.second); + } + + template + static _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 const _T2&& + get(const pair<_T1, _T2>&& __p) noexcept + { + return _CUDA_VSTD::forward(__p.second); + } }; template @@ -777,71 +792,63 @@ template inline _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 __tuple_element_t<_Ip, pair<_T1, _T2>>&& get(pair<_T1, _T2>&& __p) noexcept { - return __get_pair<_Ip>::get(_CUDA_VSTD::move(__p)); + return __get_pair<_Ip>::get(_CUDA_VSTD::move(__p)); } template inline _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX11 const __tuple_element_t<_Ip, pair<_T1, _T2>>&& get(const pair<_T1, _T2>&& __p) noexcept { - return __get_pair<_Ip>::get(_CUDA_VSTD::move(__p)); + return __get_pair<_Ip>::get(_CUDA_VSTD::move(__p)); } #if _CCCL_STD_VER > 2011 template -inline _LIBCUDACXX_INLINE_VISIBILITY -constexpr _T1 & get(pair<_T1, _T2>& __p) noexcept +inline _LIBCUDACXX_INLINE_VISIBILITY constexpr _T1& get(pair<_T1, _T2>& __p) noexcept { - return __get_pair<0>::get(__p); + return __get_pair<0>::get(__p); } template -inline _LIBCUDACXX_INLINE_VISIBILITY -constexpr _T1 const & get(pair<_T1, _T2> const& __p) noexcept +inline _LIBCUDACXX_INLINE_VISIBILITY constexpr _T1 const& get(pair<_T1, _T2> const& __p) noexcept { - return __get_pair<0>::get(__p); + return __get_pair<0>::get(__p); } template -inline _LIBCUDACXX_INLINE_VISIBILITY -constexpr _T1 && get(pair<_T1, _T2>&& __p) noexcept +inline _LIBCUDACXX_INLINE_VISIBILITY constexpr _T1&& get(pair<_T1, _T2>&& __p) noexcept { - return __get_pair<0>::get(_CUDA_VSTD::move(__p)); + return __get_pair<0>::get(_CUDA_VSTD::move(__p)); } template -inline _LIBCUDACXX_INLINE_VISIBILITY -constexpr _T1 const && get(pair<_T1, _T2> const&& __p) noexcept +inline _LIBCUDACXX_INLINE_VISIBILITY constexpr _T1 const&& get(pair<_T1, _T2> const&& __p) noexcept { - return __get_pair<0>::get(_CUDA_VSTD::move(__p)); + return __get_pair<0>::get(_CUDA_VSTD::move(__p)); } template -inline _LIBCUDACXX_INLINE_VISIBILITY -constexpr _T1 & get(pair<_T2, _T1>& __p) noexcept +inline _LIBCUDACXX_INLINE_VISIBILITY constexpr _T1& get(pair<_T2, _T1>& __p) noexcept { - return __get_pair<1>::get(__p); + return __get_pair<1>::get(__p); } template -inline _LIBCUDACXX_INLINE_VISIBILITY -constexpr _T1 const & get(pair<_T2, _T1> const& __p) noexcept +inline _LIBCUDACXX_INLINE_VISIBILITY constexpr _T1 const& get(pair<_T2, _T1> const& __p) noexcept { - return __get_pair<1>::get(__p); + return __get_pair<1>::get(__p); } template -inline _LIBCUDACXX_INLINE_VISIBILITY -constexpr _T1 && get(pair<_T2, _T1>&& __p) noexcept +inline _LIBCUDACXX_INLINE_VISIBILITY constexpr _T1&& get(pair<_T2, _T1>&& __p) noexcept { - return __get_pair<1>::get(_CUDA_VSTD::move(__p)); + return __get_pair<1>::get(_CUDA_VSTD::move(__p)); } template -inline _LIBCUDACXX_INLINE_VISIBILITY -constexpr _T1 const && get(pair<_T2, _T1> const&& __p) noexcept +inline _LIBCUDACXX_INLINE_VISIBILITY constexpr _T1 const&& get(pair<_T2, _T1> const&& __p) noexcept { - return __get_pair<1>::get(_CUDA_VSTD::move(__p)); + return __get_pair<1>::get(_CUDA_VSTD::move(__p)); } #endif // _CCCL_STD_VER > 2011 diff --git a/libcudacxx/include/cuda/std/detail/libcxx/include/tuple b/libcudacxx/include/cuda/std/detail/libcxx/include/tuple index 7d0382d0794..4847aea15d8 100644 --- a/libcudacxx/include/cuda/std/detail/libcxx/include/tuple +++ b/libcudacxx/include/cuda/std/detail/libcxx/include/tuple @@ -1327,16 +1327,17 @@ template struct _LIBCUDACXX_TEMPLATE_VIS uses_allocator, _Alloc> : true_type {}; -template +template template -inline _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX17 -pair<_T1, _T2>::pair(piecewise_construct_t, tuple<_Args1...> &__first_args, - tuple<_Args2...> &__second_args, __tuple_indices<_I1...>, - __tuple_indices<_I2...>) - : first(_CUDA_VSTD::forward<_Args1>(_CUDA_VSTD::get<_I1>(__first_args))...), - second( - _CUDA_VSTD::forward<_Args2>(_CUDA_VSTD::get<_I2>(__second_args))...) { -} +inline _LIBCUDACXX_INLINE_VISIBILITY _LIBCUDACXX_CONSTEXPR_AFTER_CXX17 __pair_base<_T1, _T2, _IsRef>::__pair_base( + piecewise_construct_t, + tuple<_Args1...>& __first_args, + tuple<_Args2...>& __second_args, + __tuple_indices<_I1...>, + __tuple_indices<_I2...>) + : first(_CUDA_VSTD::forward<_Args1>(_CUDA_VSTD::get<_I1>(__first_args))...) + , second(_CUDA_VSTD::forward<_Args2>(_CUDA_VSTD::get<_I2>(__second_args))...) +{} #if _CCCL_STD_VER > 2014 #define _LIBCUDACXX_NOEXCEPT_RETURN(...) \ diff --git a/libcudacxx/include/cuda/std/detail/libcxx/include/type_traits b/libcudacxx/include/cuda/std/detail/libcxx/include/type_traits index 20a51a69551..126035f0084 100644 --- a/libcudacxx/include/cuda/std/detail/libcxx/include/type_traits +++ b/libcudacxx/include/cuda/std/detail/libcxx/include/type_traits @@ -423,6 +423,7 @@ namespace std #endif // __cuda_std__ #include "__assert" // all public C++ headers provide the assertion handler +#include "__fwd/pair.h" #include "__functional/identity.h" #include "__functional/invoke.h" #include "__memory/addressof.h" @@ -571,7 +572,6 @@ namespace std _LIBCUDACXX_BEGIN_NAMESPACE_STD -template struct _LIBCUDACXX_TEMPLATE_VIS pair; template class _LIBCUDACXX_TEMPLATE_VIS reference_wrapper; template struct _LIBCUDACXX_TEMPLATE_VIS hash; diff --git a/libcudacxx/test/libcudacxx/std/utilities/utility/pairs/pairs.pair/trivial_copy_move.pass.cpp b/libcudacxx/test/libcudacxx/std/utilities/utility/pairs/pairs.pair/trivial_copy_move.pass.cpp index 0033be65707..4b5854ffbb5 100644 --- a/libcudacxx/test/libcudacxx/std/utilities/utility/pairs/pairs.pair/trivial_copy_move.pass.cpp +++ b/libcudacxx/test/libcudacxx/std/utilities/utility/pairs/pairs.pair/trivial_copy_move.pass.cpp @@ -44,5 +44,18 @@ int main(int, char**) static_assert(cuda::std::is_trivially_move_constructible::value, ""); } + // extensions to ensure pair is trivially_copyable + { + static_assert(cuda::std::is_copy_assignable

::value, ""); + static_assert(cuda::std::is_trivially_copy_assignable

::value, ""); + } + { + static_assert(cuda::std::is_move_assignable

::value, ""); + static_assert(cuda::std::is_trivially_move_assignable

::value, ""); + } + { + static_assert(cuda::std::is_trivially_copyable

::value, ""); + } + return 0; }