// 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_TRANSFORMED_HPP #define BOOST_RANGE_ADAPTOR_TRANSFORMED_HPP #include #include #include #include #include #include namespace boost { namespace range_detail { // A type generator to produce the transform_iterator type conditionally // including a wrapped predicate as appropriate. template struct transform_iterator_gen { typedef transform_iterator< typename default_constructible_unary_fn_gen< P, typename transform_iterator::reference >::type, It > type; }; template< class F, class R > struct transformed_range : public boost::iterator_range< typename transform_iterator_gen< F, typename range_iterator::type>::type> { private: typedef typename transform_iterator_gen< F, typename range_iterator::type>::type transform_iter_t; typedef boost::iterator_range base; public: typedef typename default_constructible_unary_fn_gen< F, typename transform_iterator< F, typename range_iterator::type >::reference >::type transform_fn_type; typedef R source_range_type; transformed_range(transform_fn_type f, R& r) : base(transform_iter_t(boost::begin(r), f), transform_iter_t(boost::end(r), f)) { } }; template< class T > struct transform_holder : holder { transform_holder( T r ) : holder(r) { } }; template< class SinglePassRange, class UnaryFunction > inline transformed_range operator|( SinglePassRange& r, const transform_holder& f ) { BOOST_RANGE_CONCEPT_ASSERT(( SinglePassRangeConcept)); return transformed_range( f.val, r ); } template< class SinglePassRange, class UnaryFunction > inline transformed_range operator|( const SinglePassRange& r, const transform_holder& f ) { BOOST_RANGE_CONCEPT_ASSERT(( SinglePassRangeConcept)); return transformed_range( f.val, r); } } // 'range_detail' using range_detail::transformed_range; namespace adaptors { namespace { const range_detail::forwarder transformed = range_detail::forwarder(); } template inline transformed_range transform(SinglePassRange& rng, UnaryFunction fn) { BOOST_RANGE_CONCEPT_ASSERT(( SinglePassRangeConcept)); return transformed_range(fn, rng); } template inline transformed_range transform(const SinglePassRange& rng, UnaryFunction fn) { BOOST_RANGE_CONCEPT_ASSERT(( SinglePassRangeConcept)); return transformed_range( fn, rng); } } // 'adaptors' } #endif