123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178 |
- /////////////////////////////////////////////////////////////////////////////
- //
- // (C) Copyright Ion Gaztanaga 2014-2014
- //
- // Distributed under the Boost Software License, Version 1.0.
- // (See accompanying file LICENSE_1_0.txt or copy at
- // http://www.boost.org/LICENSE_1_0.txt)
- //
- // See http://www.boost.org/libs/move for documentation.
- //
- /////////////////////////////////////////////////////////////////////////////
- #ifndef BOOST_MOVE_DETAIL_REVERSE_ITERATOR_HPP
- #define BOOST_MOVE_DETAIL_REVERSE_ITERATOR_HPP
- #ifndef BOOST_CONFIG_HPP
- # include <boost/config.hpp>
- #endif
- #if defined(BOOST_HAS_PRAGMA_ONCE)
- # pragma once
- #endif
- #include <boost/move/detail/config_begin.hpp>
- #include <boost/move/detail/iterator_traits.hpp>
- #include <boost/move/detail/meta_utils.hpp>
- namespace boost {
- namespace movelib {
- template<class I>
- inline typename iterator_traits<I>::pointer iterator_arrow_result(const I &i)
- { return i.operator->(); }
- template<class T>
- BOOST_MOVE_FORCEINLINE T * iterator_arrow_result(T *p)
- { return p; }
- template<class It>
- class reverse_iterator
- {
- public:
- typedef typename boost::movelib::iterator_traits<It>::pointer pointer;
- typedef typename boost::movelib::iterator_traits<It>::reference reference;
- typedef typename boost::movelib::iterator_traits<It>::difference_type difference_type;
- typedef typename boost::movelib::iterator_traits<It>::iterator_category iterator_category;
- typedef typename boost::movelib::iterator_traits<It>::value_type value_type;
- typedef It iterator_type;
- inline reverse_iterator()
- : m_current() //Value initialization to achieve "null iterators" (N3644)
- {}
- inline explicit reverse_iterator(It r)
- : m_current(r)
- {}
- inline reverse_iterator(const reverse_iterator& r)
- : m_current(r.base())
- {}
- template<class OtherIt>
- inline
- reverse_iterator( const reverse_iterator<OtherIt>& r
- , typename boost::move_detail::enable_if_convertible<OtherIt, It>::type* =0
- )
- : m_current(r.base())
- {}
- inline reverse_iterator & operator=( const reverse_iterator& r)
- { m_current = r.base(); return *this; }
- template<class OtherIt>
- inline typename boost::move_detail::enable_if_convertible<OtherIt, It, reverse_iterator &>::type
- operator=( const reverse_iterator<OtherIt>& r)
- { m_current = r.base(); return *this; }
- inline It base() const
- { return m_current; }
- inline reference operator*() const
- {
- It temp(m_current);
- --temp;
- reference r = *temp;
- return r;
- }
- inline pointer operator->() const
- {
- It temp(m_current);
- --temp;
- return (iterator_arrow_result)(temp);
- }
- inline reference operator[](difference_type off) const
- {
- return this->m_current[difference_type(-off - 1)];
- }
- inline reverse_iterator& operator++()
- {
- --m_current;
- return *this;
- }
- inline reverse_iterator operator++(int)
- {
- reverse_iterator temp((*this));
- --m_current;
- return temp;
- }
- inline reverse_iterator& operator--()
- {
- ++m_current;
- return *this;
- }
- inline reverse_iterator operator--(int)
- {
- reverse_iterator temp((*this));
- ++m_current;
- return temp;
- }
- inline friend bool operator==(const reverse_iterator& l, const reverse_iterator& r)
- { return l.m_current == r.m_current; }
- inline friend bool operator!=(const reverse_iterator& l, const reverse_iterator& r)
- { return l.m_current != r.m_current; }
- inline friend bool operator<(const reverse_iterator& l, const reverse_iterator& r)
- { return l.m_current > r.m_current; }
- inline friend bool operator<=(const reverse_iterator& l, const reverse_iterator& r)
- { return l.m_current >= r.m_current; }
- inline friend bool operator>(const reverse_iterator& l, const reverse_iterator& r)
- { return l.m_current < r.m_current; }
- inline friend bool operator>=(const reverse_iterator& l, const reverse_iterator& r)
- { return l.m_current <= r.m_current; }
- inline reverse_iterator& operator+=(difference_type off)
- { m_current -= off; return *this; }
- inline reverse_iterator& operator-=(difference_type off)
- { m_current += off; return *this; }
- inline friend reverse_iterator operator+(reverse_iterator l, difference_type off)
- { return (l += off); }
- inline friend reverse_iterator operator+(difference_type off, reverse_iterator r)
- { return (r += off); }
- inline friend reverse_iterator operator-(reverse_iterator l, difference_type off)
- { return (l-= off); }
- inline friend difference_type operator-(const reverse_iterator& l, const reverse_iterator& r)
- { return r.m_current - l.m_current; }
- private:
- It m_current; // the wrapped iterator
- };
- template< class Iterator >
- inline reverse_iterator<Iterator> make_reverse_iterator( Iterator i )
- { return reverse_iterator<Iterator>(i); }
- } //namespace movelib {
- } //namespace boost {
- #include <boost/move/detail/config_end.hpp>
- #endif //BOOST_MOVE_DETAIL_REVERSE_ITERATOR_HPP
|