#ifndef ZFP_POINTER1_HPP #define ZFP_POINTER1_HPP namespace zfp { namespace internal { namespace dim1 { // const pointer to a 1D array or view element template class const_pointer : public const_handle { public: typedef Container container_type; typedef typename container_type::value_type value_type; // default constructor const_pointer() : const_handle(0, 0) {} #if defined(__cplusplus) && __cplusplus >= 201103L const_pointer(std::nullptr_t) : const_handle(0, 0) {} #endif // constructor explicit const_pointer(const container_type* container, size_t x) : const_handle(container, x) {} // dereference pointer const_reference operator*() const { return const_reference(container, x); } const_reference operator[](ptrdiff_t d) const { return *operator+(d); } // pointer arithmetic const_pointer operator+(ptrdiff_t d) const { const_pointer p = *this; p.advance(d); return p; } const_pointer operator-(ptrdiff_t d) const { return operator+(-d); } ptrdiff_t operator-(const const_pointer& p) const { return offset() - p.offset(); } // equality operators bool operator==(const const_pointer& p) const { return container == p.container && x == p.x; } bool operator!=(const const_pointer& p) const { return !operator==(p); } // relational operators bool operator<=(const const_pointer& p) const { return container == p.container && offset() <= p.offset(); } bool operator>=(const const_pointer& p) const { return container == p.container && offset() >= p.offset(); } bool operator<(const const_pointer& p) const { return container == p.container && offset() < p.offset(); } bool operator>(const const_pointer& p) const { return container == p.container && offset() > p.offset(); } // increment and decrement const_pointer& operator++() { increment(); return *this; } const_pointer& operator--() { decrement(); return *this; } const_pointer operator++(int) { const_pointer p = *this; increment(); return p; } const_pointer operator--(int) { const_pointer p = *this; decrement(); return p; } const_pointer operator+=(ptrdiff_t d) { advance(+d); return *this; } const_pointer operator-=(ptrdiff_t d) { advance(-d); return *this; } protected: ptrdiff_t offset(ptrdiff_t d = 0) const { return static_cast(x - container->min_x()) + d; } void index(size_t& x, ptrdiff_t p) const { x = container->min_x() + size_t(p); } void advance(ptrdiff_t d) { index(x, offset(d)); } void increment() { ++x; } void decrement() { --x; } using const_handle::container; using const_handle::x; }; // pointer to a 1D array or view element template class pointer : public const_pointer { public: typedef Container container_type; typedef typename container_type::value_type value_type; // default constructor pointer() : const_pointer(0, 0) {} #if defined(__cplusplus) && __cplusplus >= 201103L pointer(std::nullptr_t) : const_pointer(0, 0) {} #endif // constructor explicit pointer(container_type* container, size_t x) : const_pointer(container, x) {} // dereference pointer reference operator*() const { return reference(container, x); } reference operator[](ptrdiff_t d) const { return *operator+(d); } // pointer arithmetic pointer operator+(ptrdiff_t d) const { pointer p = *this; p.advance(d); return p; } pointer operator-(ptrdiff_t d) const { return operator+(-d); } ptrdiff_t operator-(const pointer& p) const { return offset() - p.offset(); } // equality operators bool operator==(const pointer& p) const { return container == p.container && x == p.x; } bool operator!=(const pointer& p) const { return !operator==(p); } // relational operators bool operator<=(const pointer& p) const { return container == p.container && offset() <= p.offset(); } bool operator>=(const pointer& p) const { return container == p.container && offset() >= p.offset(); } bool operator<(const pointer& p) const { return container == p.container && offset() < p.offset(); } bool operator>(const pointer& p) const { return container == p.container && offset() > p.offset(); } // increment and decrement pointer& operator++() { increment(); return *this; } pointer& operator--() { decrement(); return *this; } pointer operator++(int) { pointer p = *this; increment(); return p; } pointer operator--(int) { pointer p = *this; decrement(); return p; } pointer operator+=(ptrdiff_t d) { advance(+d); return *this; } pointer operator-=(ptrdiff_t d) { advance(-d); return *this; } protected: using const_pointer::offset; using const_pointer::advance; using const_pointer::increment; using const_pointer::decrement; using const_pointer::container; using const_pointer::x; }; } // dim1 } // internal } // zfp #endif