const_ptr.hpp 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. //
  2. // const_ptr.hpp
  3. // pointers
  4. //
  5. // Created by Sam Jaffe on 1/5/17.
  6. //
  7. #pragma once
  8. #include <memory>
  9. #include "pointer_fwd.hpp"
  10. #include "ptr_compare.hpp"
  11. template <typename P> class const_ptr : private detail::get_ptr<P> {
  12. public:
  13. using element_type = typename std::pointer_traits<P>::element_type;
  14. using pointer = element_type const *;
  15. using reference = element_type const &;
  16. const_ptr() noexcept : _ptr(nullptr) {}
  17. const_ptr(P const & p) noexcept(detail::is_nt_cc<P>::value) : _ptr(p) {}
  18. const_ptr(P && p) noexcept(detail::is_nt_mc<P>::value) : _ptr(std::move(p)) {}
  19. template <typename Y, typename = typename std::enable_if<
  20. std::is_constructible<P, Y>::value>::type>
  21. const_ptr(Y const & p) : _ptr(p) {}
  22. template <typename Y, typename = typename std::enable_if<
  23. std::is_constructible<P, Y>::value>::type>
  24. const_ptr(Y && p) : _ptr(std::forward<Y>(p)) {}
  25. template <typename Y>
  26. explicit operator const_ptr<Y>() const
  27. noexcept(detail::is_nt_c<P, Y>::value) {
  28. return _ptr;
  29. }
  30. operator bool() const noexcept { return static_cast<bool>(_ptr); }
  31. reference operator*() const noexcept(noexcept(*_ptr)) { return *_ptr; }
  32. pointer get() const noexcept(noexcept(detail::get_ptr<P>::get(_ptr))) {
  33. return detail::get_ptr<P>::get(_ptr);
  34. }
  35. pointer operator->() const noexcept(noexcept(get())) { return get(); }
  36. private:
  37. P _ptr;
  38. };
  39. POINTER_TEMPLATE_COMPARE(const_ptr)