// Boost.Range library // // Copyright Thorsten Ottosen, Neil Groves 2006 - 2008. 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_ADAPTOR_INDIRECTED_HPP #define BOOST_RANGE_ADAPTOR_INDIRECTED_HPP #include #include #include namespace boost { namespace range_detail { template< class R > struct indirected_range : public boost::iterator_range< boost::indirect_iterator< BOOST_DEDUCED_TYPENAME range_iterator::type > > { private: typedef boost::iterator_range< boost::indirect_iterator< BOOST_DEDUCED_TYPENAME range_iterator::type > > base; public: explicit indirected_range( R& r ) : base( r ) { } }; struct indirect_forwarder {}; template< class SinglePassRange > inline indirected_range operator|( SinglePassRange& r, indirect_forwarder ) { BOOST_RANGE_CONCEPT_ASSERT(( SinglePassRangeConcept)); return indirected_range( r ); } template< class SinglePassRange > inline indirected_range operator|( const SinglePassRange& r, indirect_forwarder ) { BOOST_RANGE_CONCEPT_ASSERT(( SinglePassRangeConcept)); return indirected_range( r ); } } // 'range_detail' using range_detail::indirected_range; namespace adaptors { namespace { const range_detail::indirect_forwarder indirected = range_detail::indirect_forwarder(); } template inline indirected_range indirect(SinglePassRange& rng) { BOOST_RANGE_CONCEPT_ASSERT(( SinglePassRangeConcept)); return indirected_range(rng); } template inline indirected_range indirect(const SinglePassRange& rng) { BOOST_RANGE_CONCEPT_ASSERT(( SinglePassRangeConcept)); return indirected_range(rng); } } // 'adaptors' } #endif