Boost C++ Libraries

...one of the most highly regarded and expertly designed C++ library projects in the world. Herb Sutter and Andrei Alexandrescu, C++ Coding Standards

boost/interprocess/detail/move_iterator.hpp

//////////////////////////////////////////////////////////////////////////////
//
// (C) Copyright Ion Gaztanaga 2006. 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/interprocess for documentation.
//
//////////////////////////////////////////////////////////////////////////////

#ifndef BOOST_INTERPROCESS_MOVE_ITERATOR_HPP_INCLUDED
#define BOOST_INTERPROCESS_MOVE_ITERATOR_HPP_INCLUDED

#include <iterator>
#include <boost/interprocess/detail/move.hpp>

namespace boost{
namespace interprocess{
namespace detail{

template <class It>
class move_iterator
{
   public:
   typedef It                                                              iterator_type;
   typedef typename std::iterator_traits<iterator_type>::value_type        value_type;
   #ifndef BOOST_INTERPROCESS_RVALUE_REFERENCE
   typedef typename move_type<value_type>::type                            reference;
   #else
   typedef value_type &&                                                   reference;
   #endif
   typedef typename std::iterator_traits<iterator_type>::pointer           pointer;
   typedef typename std::iterator_traits<iterator_type>::difference_type   difference_type;
   typedef typename std::iterator_traits<iterator_type>::iterator_category iterator_category;

   move_iterator()
   {}

   explicit move_iterator(It i)
      :  m_it(i)
   {}

   template <class U>
   move_iterator(const move_iterator<U>& u)
      :  m_it(u.base())
   {}

   const iterator_type &base() const
   {  return m_it;   }

   iterator_type &base()
   {  return m_it;   }

   reference operator*() const
   #ifndef BOOST_INTERPROCESS_RVALUE_REFERENCE
   {  return detail::move_impl(*m_it);  }
   #else
   {  return *m_it;  }
   #endif

   pointer   operator->() const
   {  return m_it;   }

   move_iterator& operator++()
   {  ++m_it; return *this;   }

   move_iterator<iterator_type>  operator++(int)
   {  move_iterator<iterator_type> tmp(*this); ++(*this); return tmp;   }

   move_iterator& operator--()
   {  --m_it; return *this;   }

   move_iterator<iterator_type>  operator--(int)
   {  move_iterator<iterator_type> tmp(*this); --(*this); return tmp;   }

   move_iterator<iterator_type>  operator+ (difference_type n) const
   {  return move_iterator<iterator_type>(m_it + n);  }

   move_iterator& operator+=(difference_type n)
   {  m_it += n; return *this;   }

   move_iterator<iterator_type>  operator- (difference_type n) const
   {  return move_iterator<iterator_type>(m_it - n);  }

   move_iterator& operator-=(difference_type n)
   {  m_it -= n; return *this;   }

   reference operator[](difference_type n) const
   {  return detail::move_impl(m_it[n]);   }

   private:
   It m_it;
};

template <class It> inline
bool operator==(const move_iterator<It>& x, const move_iterator<It>& y)
{  return x.base() == y.base();  }

template <class It> inline
bool operator!=(const move_iterator<It>& x, const move_iterator<It>& y)
{  return x.base() != y.base();  }

template <class It> inline
bool operator< (const move_iterator<It>& x, const move_iterator<It>& y)
{  return x.base() < y.base();   }

template <class It> inline
bool operator<=(const move_iterator<It>& x, const move_iterator<It>& y)
{  return x.base() <= y.base();  }

template <class It> inline
bool operator> (const move_iterator<It>& x, const move_iterator<It>& y)
{  return x.base() > y.base();  }

template <class It> inline
bool operator>=(const move_iterator<It>& x, const move_iterator<It>& y)
{  return x.base() >= y.base();  }

template <class It> inline
typename move_iterator<It>::difference_type
   operator-(const move_iterator<It>& x, const move_iterator<It>& y)
{  return x.base() - y.base();   }

template <class It> inline
move_iterator<It>
   operator+(typename move_iterator<It>::difference_type n
            ,const move_iterator<It>& x)
{  return move_iterator<It>(x.base() + n);   }

template<class It>
move_iterator<It> make_move_iterator(const It &it)
{  return move_iterator<It>(it); }

}  //namespace detail{
}  //namespace interprocess{
}  //namespace boost{

#endif   //#ifndef BOOST_INTERPROCESS_MOVE_ITERATOR_HPP_INCLUDED