const_ptr.hpp 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  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 "detail/compare.hpp"
  10. #include "detail/get_ptr.hpp"
  11. #include "pointer_fwd.hpp"
  12. namespace pointers {
  13. template <typename P>
  14. class const_ptr : private detail::get_ptr<P>,
  15. public detail::pointer_compare<const_ptr<P>> {
  16. public:
  17. using element_type = typename std::pointer_traits<P>::element_type;
  18. using pointer = element_type const *;
  19. using reference = element_type const &;
  20. const_ptr() noexcept : _ptr(nullptr) {}
  21. const_ptr(P const & p) noexcept(
  22. std::is_nothrow_copy_constructible<P>::value)
  23. : _ptr(p) {}
  24. const_ptr(P && p) noexcept(std::is_nothrow_move_constructible<P>::value)
  25. : _ptr(std::move(p)) {}
  26. template <typename Y, typename = typename std::enable_if<
  27. std::is_constructible<P, Y>::value>::type>
  28. const_ptr(Y const & p) : _ptr(p) {}
  29. template <typename Y, typename = typename std::enable_if<
  30. std::is_constructible<P, Y>::value>::type>
  31. const_ptr(Y && p) : _ptr(std::forward<Y>(p)) {}
  32. template <typename Y>
  33. explicit operator const_ptr<Y>() const
  34. noexcept(std::is_nothrow_constructible<P, Y>::value) {
  35. return _ptr;
  36. }
  37. operator bool() const noexcept { return static_cast<bool>(_ptr); }
  38. reference operator*() const noexcept(noexcept(*_ptr)) { return *_ptr; }
  39. pointer get() const noexcept(noexcept(detail::get_ptr<P>::get(_ptr))) {
  40. return detail::get_ptr<P>::get(_ptr);
  41. }
  42. pointer operator->() const noexcept(noexcept(get())) { return get(); }
  43. private:
  44. P _ptr;
  45. };
  46. }