thrust/device_reference.h
File members: thrust/device_reference.h
/*
 *  Copyright 2008-2013 NVIDIA Corporation
 *
 *  Licensed under the Apache License, Version 2.0 (the "License");
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 */
#pragma once
#include <thrust/detail/config.h>
#if defined(_CCCL_IMPLICIT_SYSTEM_HEADER_GCC)
#  pragma GCC system_header
#elif defined(_CCCL_IMPLICIT_SYSTEM_HEADER_CLANG)
#  pragma clang system_header
#elif defined(_CCCL_IMPLICIT_SYSTEM_HEADER_MSVC)
#  pragma system_header
#endif // no system header
#include <thrust/detail/reference.h>
#include <thrust/detail/type_traits.h>
#include <thrust/device_ptr.h>
THRUST_NAMESPACE_BEGIN
template <typename T>
class device_reference : public thrust::reference<T, thrust::device_ptr<T>, thrust::device_reference<T>>
{
private:
  using super_t = thrust::reference<T, thrust::device_ptr<T>, thrust::device_reference<T>>;
public:
  using value_type = typename super_t::value_type;
  using pointer = typename super_t::pointer;
  template <typename OtherT>
  _CCCL_HOST_DEVICE
  device_reference(const device_reference<OtherT>& other,
                   thrust::detail::enable_if_convertible_t<typename device_reference<OtherT>::pointer, pointer>* = 0)
      : super_t(other)
  {}
  _CCCL_HOST_DEVICE explicit device_reference(const pointer& ptr)
      : super_t(ptr)
  {}
  template <typename OtherT>
  _CCCL_HOST_DEVICE device_reference& operator=(const device_reference<OtherT>& other)
  {
    return super_t::operator=(other);
  }
  _CCCL_HOST_DEVICE device_reference& operator=(const value_type& x)
  {
    return super_t::operator=(x);
  }
// declare these members for the purpose of Doxygenating them
// they actually exist in a base class
#if 0
    _CCCL_HOST_DEVICE
    pointer operator&(void) const;
    _CCCL_HOST_DEVICE
    operator value_type (void) const;
    _CCCL_HOST_DEVICE
    void swap(device_reference &other);
    device_reference &operator++(void);
    value_type operator++(int);
    device_reference &operator+=(const T &rhs);
    device_reference &operator--(void);
    value_type operator--(int);
    device_reference &operator-=(const T &rhs);
    device_reference &operator*=(const T &rhs);
    device_reference &operator/=(const T &rhs);
    device_reference &operator%=(const T &rhs);
    device_reference &operator<<=(const T &rhs);
    device_reference &operator>>=(const T &rhs);
    device_reference &operator&=(const T &rhs);
    device_reference &operator|=(const T &rhs);
    device_reference &operator^=(const T &rhs);
#endif // end doxygen-only members
  _CCCL_HOST_DEVICE friend void swap(device_reference& x, device_reference& y) noexcept(noexcept(x.swap(y)))
  {
    x.swap(y);
  }
}; // end device_reference
// declare these methods for the purpose of Doxygenating them
// they actually are defined for a base class
#ifdef _CCCL_DOXYGEN_INVOKED
template <typename T, typename charT, typename traits>
std::basic_ostream<charT, traits>& operator<<(std::basic_ostream<charT, traits>& os, const device_reference<T>& y);
#endif
THRUST_NAMESPACE_END