| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 |
- // Copyright (C) 2017 Michel Morin.
- //
- // 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)
- #ifndef BOOST_ITERATOR_ADVANCE_HPP
- #define BOOST_ITERATOR_ADVANCE_HPP
- #include <boost/config.hpp>
- #include <boost/iterator/iterator_categories.hpp>
- namespace boost {
- namespace iterators {
- namespace detail {
- template< typename InputIterator, typename Distance >
- inline BOOST_CXX14_CONSTEXPR void advance_impl(InputIterator& it, Distance n, incrementable_traversal_tag)
- {
- while (n > 0)
- {
- ++it;
- --n;
- }
- }
- template< typename BidirectionalIterator, typename Distance >
- inline BOOST_CXX14_CONSTEXPR void advance_impl(BidirectionalIterator& it, Distance n, bidirectional_traversal_tag)
- {
- if (n >= 0)
- {
- while (n > 0)
- {
- ++it;
- --n;
- }
- }
- else
- {
- while (n < 0)
- {
- --it;
- ++n;
- }
- }
- }
- template< typename RandomAccessIterator, typename Distance >
- inline BOOST_CXX14_CONSTEXPR void advance_impl(RandomAccessIterator& it, Distance n, random_access_traversal_tag)
- {
- it += n;
- }
- } // namespace detail
- namespace advance_adl_barrier {
- template< typename InputIterator, typename Distance >
- inline BOOST_CXX14_CONSTEXPR void advance(InputIterator& it, Distance n)
- {
- detail::advance_impl(it, n, typename iterator_traversal< InputIterator >::type());
- }
- } // namespace advance_adl_barrier
- using namespace advance_adl_barrier;
- } // namespace iterators
- using namespace iterators::advance_adl_barrier;
- } // namespace boost
- #endif
|