Sha256: 6c3320418dc2d8474f31aec15da1bd3bde4fa09d6af12a3dda834a40534d84d6
Contents?: true
Size: 1.82 KB
Versions: 22
Compression:
Stored size: 1.82 KB
Contents
// 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_DISTANCE_HPP #define BOOST_ITERATOR_DISTANCE_HPP #include <boost/config.hpp> #include <boost/iterator/iterator_categories.hpp> #include <boost/iterator/iterator_traits.hpp> namespace boost { namespace iterators { namespace detail { template <typename SinglePassIterator> inline BOOST_CXX14_CONSTEXPR typename iterator_difference<SinglePassIterator>::type distance_impl( SinglePassIterator first , SinglePassIterator last , single_pass_traversal_tag ) { typename iterator_difference<SinglePassIterator>::type n = 0; while (first != last) { ++first; ++n; } return n; } template <typename RandomAccessIterator> inline BOOST_CXX14_CONSTEXPR typename iterator_difference<RandomAccessIterator>::type distance_impl( RandomAccessIterator first , RandomAccessIterator last , random_access_traversal_tag ) { return last - first; } } namespace distance_adl_barrier { template <typename SinglePassIterator> inline BOOST_CXX14_CONSTEXPR typename iterator_difference<SinglePassIterator>::type distance(SinglePassIterator first, SinglePassIterator last) { return detail::distance_impl( first, last, typename iterator_traversal<SinglePassIterator>::type() ); } } using namespace distance_adl_barrier; } // namespace iterators using namespace iterators::distance_adl_barrier; } // namespace boost #endif
Version data entries
22 entries across 22 versions & 1 rubygems