// Copyright Neil Groves 2010. 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_ANY_RANGE_HPP_INCLUDED #define BOOST_RANGE_ANY_RANGE_HPP_INCLUDED #include #include #include #include #include #include #include #include #include #include #include namespace boost { namespace range_detail { // If T is use_default, return the result of Default, otherwise // return T. // // This is an implementation artifact used to pick intelligent default // values when the user specified boost::use_default as a template // parameter. template< class T, class Default > struct any_range_default_help : mpl::eval_if< is_same , Default , mpl::identity > { }; template< class WrappedRange , class Value , class Reference > struct any_range_value_type { # ifdef BOOST_ITERATOR_REF_CONSTNESS_KILLS_WRITABILITY typedef typename any_range_default_help< Value , mpl::eval_if< is_same , range_value< typename remove_const ::type> , remove_reference > >::type type; # else typedef typename any_range_default_help< Value , range_value< typename remove_const ::type> >::type type; # endif }; template< class Value , class Traversal , class Reference , class Difference , class Buffer = use_default > class any_range : public iterator_range< any_iterator< Value , Traversal , Reference , Difference , typename any_range_default_help< Buffer , mpl::identity >::type > > { typedef iterator_range< any_iterator< Value , Traversal , Reference , Difference , typename any_range_default_help< Buffer , mpl::identity >::type > > base_type; struct enabler {}; struct disabler {}; public: any_range() { } any_range(const any_range& other) : base_type(other) { } template any_range(WrappedRange& wrapped_range) : base_type(boost::begin(wrapped_range), boost::end(wrapped_range)) { } template any_range(const WrappedRange& wrapped_range) : base_type(boost::begin(wrapped_range), boost::end(wrapped_range)) { } template< class OtherValue , class OtherTraversal , class OtherReference , class OtherDifference > any_range(const any_range< OtherValue , OtherTraversal , OtherReference , OtherDifference , Buffer >& other) : base_type(boost::begin(other), boost::end(other)) { } template any_range(Iterator first, Iterator last) : base_type(first, last) { } }; template< class WrappedRange , class Value = use_default , class Traversal = use_default , class Reference = use_default , class Difference = use_default , class Buffer = use_default > struct any_range_type_generator { BOOST_RANGE_CONCEPT_ASSERT(( SinglePassRangeConcept )); typedef any_range< typename any_range_value_type< WrappedRange , Value , typename any_range_default_help< Reference , range_reference >::type >::type , typename any_range_default_help< Traversal , iterator_traversal< typename range_iterator::type > >::type , typename any_range_default_help< Reference , range_reference >::type , typename any_range_default_help< Difference , range_difference >::type , typename any_range_default_help< Buffer , mpl::identity >::type > type; }; } // namespace range_detail using range_detail::any_range; using range_detail::any_range_type_generator; } // namespace boost #endif // include guard