diff --git a/src/stdgpu/impl/utility_detail.h b/src/stdgpu/impl/utility_detail.h index a913768d6..748802ca7 100644 --- a/src/stdgpu/impl/utility_detail.h +++ b/src/stdgpu/impl/utility_detail.h @@ -19,6 +19,106 @@ namespace stdgpu { +template +template < + STDGPU_DETAIL_OVERLOAD_DEFINITION_IF(std::is_default_constructible_v&& std::is_default_constructible_v)> +constexpr STDGPU_HOST_DEVICE +pair::pair() + : first() + , second() +{ +} + +template +template && std::is_copy_constructible_v)> +constexpr STDGPU_HOST_DEVICE +pair::pair(const T1& x, const T2& y) + : first(x) + , second(y) +{ +} + +template +template && std::is_constructible_v)> +constexpr STDGPU_HOST_DEVICE +pair::pair(U1&& x, U2&& y) + : first(forward(x)) + , second(forward(y)) +{ +} + +template +template && std::is_constructible_v)> +constexpr STDGPU_HOST_DEVICE +pair::pair(pair& p) + : first(p.first) + , second(p.second) +{ +} + +template +template && std::is_constructible_v)> +constexpr STDGPU_HOST_DEVICE +pair::pair(const pair& p) + : first(p.first) + , second(p.second) +{ +} + +template +template && std::is_constructible_v)> +constexpr STDGPU_HOST_DEVICE +pair::pair(pair&& p) + : first(forward(p.first)) + , second(forward(p.second)) +{ +} + +template +template && std::is_constructible_v)> +constexpr STDGPU_HOST_DEVICE +pair::pair(const pair&& p) + : first(forward(p.first)) + , second(forward(p.second)) +{ +} + +template +template && std::is_assignable_v)> +constexpr STDGPU_HOST_DEVICE pair& +pair::operator=(const pair& p) +{ + first = p.first; + second = p.second; + return *this; +} + +template +template && std::is_assignable_v)> +constexpr STDGPU_HOST_DEVICE pair& +pair::operator=(pair&& p) +{ + first = forward(p.first); + second = forward(p.second); + return *this; +} + template constexpr STDGPU_HOST_DEVICE T&& forward(std::remove_reference_t& t) noexcept diff --git a/src/stdgpu/utility.h b/src/stdgpu/utility.h index 61e697e5b..04c2afae5 100644 --- a/src/stdgpu/utility.h +++ b/src/stdgpu/utility.h @@ -25,10 +25,10 @@ * \file stdgpu/utility.h */ -#include #include #include +#include namespace stdgpu { @@ -40,7 +40,153 @@ namespace stdgpu * \brief A pair of two values of potentially different types */ template -using pair = thrust::pair; +struct pair +{ + using first_type = T1; /**< T1 */ + using second_type = T2; /**< T2 */ + + /** + * \brief Default Destructor + */ + ~pair() = default; + + /** + * \brief Constructor + */ + template && std::is_default_constructible_v)> + constexpr STDGPU_HOST_DEVICE + pair(); + + /** + * \brief Constructor + * \param[in] x The new first element + * \param[in] y The new second element + */ + template && std::is_copy_constructible_v)> + constexpr STDGPU_HOST_DEVICE + pair(const T1& x, const T2& y); + + /** + * \brief Constructor + * \tparam U1 The type of the first element + * \tparam U2 The type of the second element + * \param[in] x The new first element + * \param[in] y The new second element + */ + template && std::is_constructible_v)> + constexpr STDGPU_HOST_DEVICE + pair(U1&& x, U2&& y); + + /** + * \brief Copy constructor + * \tparam U1 The type of the other pair's first element + * \tparam U2 The type of the other pair's second element + * \param[in] p The pair to copy from + */ + template && std::is_constructible_v)> + constexpr STDGPU_HOST_DEVICE + pair(pair& p); // NOLINT(hicpp-explicit-conversions) + + /** + * \brief Copy constructor + * \tparam U1 The type of the other pair's first element + * \tparam U2 The type of the other pair's second element + * \param[in] p The copied pair + */ + template < + typename U1, + typename U2, + STDGPU_DETAIL_OVERLOAD_IF(std::is_constructible_v&& std::is_constructible_v)> + constexpr STDGPU_HOST_DEVICE + pair(const pair& p); // NOLINT(hicpp-explicit-conversions) + + /** + * \brief Move constructor + * \tparam U1 The type of the other pair's first element + * \tparam U2 The type of the other pair's second element + * \param[in] p The moved pair + */ + template && std::is_constructible_v)> + constexpr STDGPU_HOST_DEVICE + pair(pair&& p); // NOLINT(hicpp-explicit-conversions) + + /** + * \brief Move constructor + * \tparam U1 The type of the other pair's first element + * \tparam U2 The type of the other pair's second element + * \param[in] p The moved pair + */ + template && std::is_constructible_v)> + constexpr STDGPU_HOST_DEVICE + pair(const pair&& p); // NOLINT(hicpp-explicit-conversions) + + /** + * \brief Default copy constructor + * \param[in] p The copied pair + */ + pair(const pair& p) = default; + + /** + * \brief Default move constructor + * \param[in] p The moved pair + */ + pair(pair&& p) = default; // NOLINT(hicpp-noexcept-move,performance-noexcept-move-constructor) + + /** + * \brief Default copy assignment operator + * \param[in] p The pair to copy from + * \return *this + */ + pair& + operator=(const pair& p) = default; + + /** + * \brief Copy assignment operator + * \tparam U1 The type of the other pair's first element + * \tparam U2 The type of the other pair's second element + * \param[in] p The pair to copy from + * \return *this + */ + template && std::is_assignable_v)> + constexpr STDGPU_HOST_DEVICE pair& + operator=(const pair& p); + + /** + * \brief Default move assignment operator + * \param[in] p The moved pair + * \return *this + */ + pair& + operator=(pair&& p) = default; // NOLINT(hicpp-noexcept-move,performance-noexcept-move-constructor) + + /** + * \brief Move assignment operator + * \tparam U1 The type of the other pair's first element + * \tparam U2 The type of the other pair's second element + * \param[in] p The moved pair + * \return *this + */ + template && std::is_assignable_v)> + constexpr STDGPU_HOST_DEVICE pair& + operator=(pair&& p); + + // NOLINTNEXTLINE(misc-non-private-member-variables-in-classes) + first_type first; /**< First element of pair */ + // NOLINTNEXTLINE(misc-non-private-member-variables-in-classes) + second_type second; /**< Second element of pair */ +}; /** * \ingroup utility