From ee3222fbbb7e30843378dc4dddf644e6c55c7a3e Mon Sep 17 00:00:00 2001 From: vuule Date: Thu, 5 May 2022 16:21:28 -0700 Subject: [PATCH] fix const correctness of element access in hostdevice_vector --- cpp/src/io/utilities/hostdevice_vector.hpp | 27 ++++++++++++++-------- 1 file changed, 18 insertions(+), 9 deletions(-) diff --git a/cpp/src/io/utilities/hostdevice_vector.hpp b/cpp/src/io/utilities/hostdevice_vector.hpp index 30c7b6ec326..f9316625dde 100644 --- a/cpp/src/io/utilities/hostdevice_vector.hpp +++ b/cpp/src/io/utilities/hostdevice_vector.hpp @@ -81,17 +81,26 @@ class hostdevice_vector { [[nodiscard]] size_t size() const noexcept { return num_elements; } [[nodiscard]] size_t memory_size() const noexcept { return sizeof(T) * num_elements; } - T& operator[](size_t i) const { return h_data[i]; } - T* host_ptr(size_t offset = 0) const { return h_data + offset; } + T& operator[](size_t i) { return h_data[i]; } + T const& operator[](size_t i) const { return h_data[i]; } + + T* host_ptr(size_t offset = 0) { return h_data + offset; } + T const* host_ptr(size_t offset = 0) const { return h_data + offset; } + T* begin() { return h_data; } + T const* begin() const { return h_data; } + T* end() { return h_data + num_elements; } - T* d_begin() { return static_cast(d_data.data()); } - T* d_end() { return static_cast(d_data.data()) + num_elements; } - T* device_ptr(size_t offset = 0) { return reinterpret_cast(d_data.data()) + offset; } - T const* device_ptr(size_t offset = 0) const - { - return reinterpret_cast(d_data.data()) + offset; - } + T const* end() const { return h_data + num_elements; } + + auto d_begin() { return static_cast(d_data.data()); } + auto d_begin() const { return static_cast(d_data.data()); } + + auto d_end() { return static_cast(d_data.data()) + num_elements; } + auto d_end() const { return static_cast(d_data.data()) + num_elements; } + + auto device_ptr(size_t offset = 0) { return static_cast(d_data.data()) + offset; } + auto device_ptr(size_t offset = 0) const { return static_cast(d_data.data()) + offset; } /** * @brief Returns the specified element from device memory