// Boost.Range library // // Copyright Thorsten Ottosen 2003-2004. Use, modification and // distribution is subject to 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) // // For more information, see http://www.boost.org/libs/range/ // #ifndef BOOST_RANGE_SIZE_HPP #define BOOST_RANGE_SIZE_HPP #if defined(_MSC_VER) # pragma once #endif #include #include #include #include #include #include #include #include namespace lslboost { namespace range_detail { template inline typename ::lslboost::enable_if< has_member_size, typename range_size::type >::type range_calculate_size(const SinglePassRange& rng) { return rng.size(); } template inline typename disable_if< has_member_size, typename range_size::type >::type range_calculate_size(const SinglePassRange& rng) { return std::distance(lslboost::begin(rng), lslboost::end(rng)); } } template inline typename range_size::type size(const SinglePassRange& rng) { // Very strange things happen on some compilers that have the range concept // asserts disabled. This preprocessor condition is clearly redundant on a // working compiler but is vital for at least some compilers such as clang 4.2 // but only on the Mac! #if BOOST_RANGE_ENABLE_CONCEPT_ASSERT == 1 BOOST_RANGE_CONCEPT_ASSERT((lslboost::SinglePassRangeConcept)); #endif #if !BOOST_WORKAROUND(__BORLANDC__, BOOST_TESTED_AT(0x564)) && \ !BOOST_WORKAROUND(__GNUC__, < 3) \ /**/ using namespace range_detail; #endif return range_calculate_size(rng); } } // namespace 'boost' #endif