// 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_DISTANCE_HPP #define BOOST_ITERATOR_DISTANCE_HPP #include #include #include namespace boost { namespace iterators { namespace detail { template inline BOOST_CXX14_CONSTEXPR typename iterator_difference::type distance_impl( SinglePassIterator first , SinglePassIterator last , single_pass_traversal_tag ) { typename iterator_difference::type n = 0; while (first != last) { ++first; ++n; } return n; } template inline BOOST_CXX14_CONSTEXPR typename iterator_difference::type distance_impl( RandomAccessIterator first , RandomAccessIterator last , random_access_traversal_tag ) { return last - first; } } namespace distance_adl_barrier { template inline BOOST_CXX14_CONSTEXPR typename iterator_difference::type distance(SinglePassIterator first, SinglePassIterator last) { return detail::distance_impl( first, last, typename iterator_traversal::type() ); } } using namespace distance_adl_barrier; } // namespace iterators using iterators::distance; } // namespace boost #endif