205 lines
		
	
	
		
			6.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			205 lines
		
	
	
		
			6.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| // 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_MAP_HPP
 | |
| #define BOOST_RANGE_ADAPTOR_MAP_HPP
 | |
| 
 | |
| #include <boost/range/adaptor/transformed.hpp>
 | |
| #include <boost/range/iterator_range.hpp>
 | |
| #include <boost/range/value_type.hpp>
 | |
| #include <boost/range/reference.hpp>
 | |
| #include <boost/range/concepts.hpp>
 | |
| 
 | |
| namespace boost
 | |
| {
 | |
|     namespace range_detail
 | |
|     {
 | |
|         struct map_keys_forwarder {};
 | |
|         struct map_values_forwarder {};
 | |
| 
 | |
|         template< class Map >
 | |
|         struct select_first
 | |
|         {
 | |
|             typedef BOOST_DEDUCED_TYPENAME range_reference<const Map>::type argument_type;
 | |
|             typedef const BOOST_DEDUCED_TYPENAME range_value<const Map>::type::first_type& result_type;
 | |
| 
 | |
|             result_type operator()( argument_type r ) const
 | |
|             {
 | |
|                 return r.first;
 | |
|             }
 | |
|         };
 | |
| 
 | |
|         template< class Map >
 | |
|         struct select_second_mutable
 | |
|         {
 | |
|             typedef BOOST_DEDUCED_TYPENAME range_reference<Map>::type argument_type;
 | |
|             typedef BOOST_DEDUCED_TYPENAME range_value<Map>::type::second_type& result_type;
 | |
| 
 | |
|             result_type operator()( argument_type r ) const
 | |
|             {
 | |
|                 return r.second;
 | |
|             }
 | |
|         };
 | |
| 
 | |
|         template< class Map >
 | |
|         struct select_second_const
 | |
|         {
 | |
|             typedef BOOST_DEDUCED_TYPENAME range_reference<const Map>::type argument_type;
 | |
|             typedef const BOOST_DEDUCED_TYPENAME range_value<const Map>::type::second_type& result_type;
 | |
| 
 | |
|             result_type operator()( argument_type r ) const
 | |
|             {
 | |
|                 return r.second;
 | |
|             }
 | |
|         };
 | |
| 
 | |
|         template<class StdPairRng>
 | |
|         class select_first_range
 | |
|             : public transformed_range<
 | |
|                         select_first<StdPairRng>,
 | |
|                         const StdPairRng>
 | |
|         {
 | |
|             typedef transformed_range<select_first<StdPairRng>, const StdPairRng> base;
 | |
|         public:
 | |
|             typedef select_first<StdPairRng> transform_fn_type;
 | |
|             typedef const StdPairRng source_range_type;
 | |
| 
 | |
|             select_first_range(transform_fn_type fn, source_range_type& rng)
 | |
|                 : base(fn, rng)
 | |
|             {
 | |
|             }
 | |
| 
 | |
|             select_first_range(const base& other) : base(other) {}
 | |
|         };
 | |
| 
 | |
|         template<class StdPairRng>
 | |
|         class select_second_mutable_range
 | |
|             : public transformed_range<
 | |
|                         select_second_mutable<StdPairRng>,
 | |
|                         StdPairRng>
 | |
|         {
 | |
|             typedef transformed_range<select_second_mutable<StdPairRng>, StdPairRng> base;
 | |
|         public:
 | |
|             typedef select_second_mutable<StdPairRng> transform_fn_type;
 | |
|             typedef StdPairRng source_range_type;
 | |
| 
 | |
|             select_second_mutable_range(transform_fn_type fn, source_range_type& rng)
 | |
|                 : base(fn, rng)
 | |
|             {
 | |
|             }
 | |
| 
 | |
|             select_second_mutable_range(const base& other) : base(other) {}
 | |
|         };
 | |
| 
 | |
|         template<class StdPairRng>
 | |
|         class select_second_const_range
 | |
|             : public transformed_range<
 | |
|                         select_second_const<StdPairRng>,
 | |
|                         const StdPairRng>
 | |
|         {
 | |
|             typedef transformed_range<select_second_const<StdPairRng>, const StdPairRng> base;
 | |
|         public:
 | |
|             typedef select_second_const<StdPairRng> transform_fn_type;
 | |
|             typedef const StdPairRng source_range_type;
 | |
| 
 | |
|             select_second_const_range(transform_fn_type fn, source_range_type& rng)
 | |
|                 : base(fn, rng)
 | |
|             {
 | |
|             }
 | |
| 
 | |
|             select_second_const_range(const base& other) : base(other) {}
 | |
|         };
 | |
| 
 | |
|         template< class StdPairRng >
 | |
|         inline select_first_range<StdPairRng>
 | |
|         operator|( const StdPairRng& r, map_keys_forwarder )
 | |
|         {
 | |
|             BOOST_RANGE_CONCEPT_ASSERT((
 | |
|                 SinglePassRangeConcept<const StdPairRng>));
 | |
| 
 | |
|             return operator|( r,
 | |
|                 boost::adaptors::transformed( select_first<StdPairRng>() ) );
 | |
|         }
 | |
| 
 | |
|         template< class StdPairRng >
 | |
|         inline select_second_mutable_range<StdPairRng>
 | |
|         operator|( StdPairRng& r, map_values_forwarder )
 | |
|         {
 | |
|             BOOST_RANGE_CONCEPT_ASSERT((SinglePassRangeConcept<StdPairRng>));
 | |
| 
 | |
|             return operator|( r,
 | |
|                 boost::adaptors::transformed( select_second_mutable<StdPairRng>() ) );
 | |
|         }
 | |
| 
 | |
|         template< class StdPairRng >
 | |
|         inline select_second_const_range<StdPairRng>
 | |
|         operator|( const StdPairRng& r, map_values_forwarder )
 | |
|         {
 | |
|             BOOST_RANGE_CONCEPT_ASSERT((
 | |
|                 SinglePassRangeConcept<const StdPairRng>));
 | |
| 
 | |
|             return operator|( r,
 | |
|                 boost::adaptors::transformed( select_second_const<StdPairRng>() ) );
 | |
|         }
 | |
| 
 | |
|     } // 'range_detail'
 | |
| 
 | |
|     using range_detail::select_first_range;
 | |
|     using range_detail::select_second_mutable_range;
 | |
|     using range_detail::select_second_const_range;
 | |
| 
 | |
|     namespace adaptors
 | |
|     {
 | |
|         namespace
 | |
|         {
 | |
|             const range_detail::map_keys_forwarder map_keys =
 | |
|                                             range_detail::map_keys_forwarder();
 | |
| 
 | |
|             const range_detail::map_values_forwarder map_values =
 | |
|                                            range_detail::map_values_forwarder();
 | |
|         }
 | |
| 
 | |
|         template<class StdPairRange>
 | |
|         inline select_first_range<StdPairRange>
 | |
|         keys(const StdPairRange& rng)
 | |
|         {
 | |
|             BOOST_RANGE_CONCEPT_ASSERT((
 | |
|                 SinglePassRangeConcept<const StdPairRange>));
 | |
| 
 | |
|             return select_first_range<StdPairRange>(
 | |
|                 range_detail::select_first<StdPairRange>(), rng );
 | |
|         }
 | |
| 
 | |
|         template<class StdPairRange>
 | |
|         inline select_second_const_range<StdPairRange>
 | |
|         values(const StdPairRange& rng)
 | |
|         {
 | |
|             BOOST_RANGE_CONCEPT_ASSERT((
 | |
|                 SinglePassRangeConcept<const StdPairRange>));
 | |
| 
 | |
|             return select_second_const_range<StdPairRange>(
 | |
|                 range_detail::select_second_const<StdPairRange>(), rng );
 | |
|         }
 | |
| 
 | |
|         template<class StdPairRange>
 | |
|         inline select_second_mutable_range<StdPairRange>
 | |
|         values(StdPairRange& rng)
 | |
|         {
 | |
|             BOOST_RANGE_CONCEPT_ASSERT((SinglePassRangeConcept<StdPairRange>));
 | |
| 
 | |
|             return select_second_mutable_range<StdPairRange>(
 | |
|                 range_detail::select_second_mutable<StdPairRange>(), rng );
 | |
|         }
 | |
|     } // 'adaptors'
 | |
| 
 | |
| }
 | |
| 
 | |
| #endif
 | 
