Chris@16
|
1 // Boost.Range library
|
Chris@16
|
2 //
|
Chris@16
|
3 // Copyright Thorsten Ottosen, Neil Groves 2006 - 2008. Use, modification and
|
Chris@16
|
4 // distribution is subject to the Boost Software License, Version
|
Chris@16
|
5 // 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
Chris@16
|
6 // http://www.boost.org/LICENSE_1_0.txt)
|
Chris@16
|
7 //
|
Chris@16
|
8 // For more information, see http://www.boost.org/libs/range/
|
Chris@16
|
9 //
|
Chris@16
|
10
|
Chris@16
|
11 #ifndef BOOST_RANGE_ADAPTOR_MAP_HPP
|
Chris@16
|
12 #define BOOST_RANGE_ADAPTOR_MAP_HPP
|
Chris@16
|
13
|
Chris@16
|
14 #include <boost/range/adaptor/transformed.hpp>
|
Chris@16
|
15 #include <boost/range/iterator_range.hpp>
|
Chris@16
|
16 #include <boost/range/value_type.hpp>
|
Chris@16
|
17 #include <boost/range/reference.hpp>
|
Chris@101
|
18 #include <boost/range/concepts.hpp>
|
Chris@16
|
19
|
Chris@16
|
20 namespace boost
|
Chris@16
|
21 {
|
Chris@16
|
22 namespace range_detail
|
Chris@16
|
23 {
|
Chris@16
|
24 struct map_keys_forwarder {};
|
Chris@16
|
25 struct map_values_forwarder {};
|
Chris@16
|
26
|
Chris@16
|
27 template< class Map >
|
Chris@16
|
28 struct select_first
|
Chris@16
|
29 {
|
Chris@16
|
30 typedef BOOST_DEDUCED_TYPENAME range_reference<const Map>::type argument_type;
|
Chris@16
|
31 typedef const BOOST_DEDUCED_TYPENAME range_value<const Map>::type::first_type& result_type;
|
Chris@16
|
32
|
Chris@16
|
33 result_type operator()( argument_type r ) const
|
Chris@16
|
34 {
|
Chris@16
|
35 return r.first;
|
Chris@16
|
36 }
|
Chris@16
|
37 };
|
Chris@16
|
38
|
Chris@16
|
39 template< class Map >
|
Chris@16
|
40 struct select_second_mutable
|
Chris@16
|
41 {
|
Chris@16
|
42 typedef BOOST_DEDUCED_TYPENAME range_reference<Map>::type argument_type;
|
Chris@16
|
43 typedef BOOST_DEDUCED_TYPENAME range_value<Map>::type::second_type& result_type;
|
Chris@16
|
44
|
Chris@16
|
45 result_type operator()( argument_type r ) const
|
Chris@16
|
46 {
|
Chris@16
|
47 return r.second;
|
Chris@16
|
48 }
|
Chris@16
|
49 };
|
Chris@16
|
50
|
Chris@16
|
51 template< class Map >
|
Chris@16
|
52 struct select_second_const
|
Chris@16
|
53 {
|
Chris@16
|
54 typedef BOOST_DEDUCED_TYPENAME range_reference<const Map>::type argument_type;
|
Chris@16
|
55 typedef const BOOST_DEDUCED_TYPENAME range_value<const Map>::type::second_type& result_type;
|
Chris@16
|
56
|
Chris@16
|
57 result_type operator()( argument_type r ) const
|
Chris@16
|
58 {
|
Chris@16
|
59 return r.second;
|
Chris@16
|
60 }
|
Chris@16
|
61 };
|
Chris@16
|
62
|
Chris@16
|
63 template<class StdPairRng>
|
Chris@16
|
64 class select_first_range
|
Chris@16
|
65 : public transformed_range<
|
Chris@16
|
66 select_first<StdPairRng>,
|
Chris@16
|
67 const StdPairRng>
|
Chris@16
|
68 {
|
Chris@16
|
69 typedef transformed_range<select_first<StdPairRng>, const StdPairRng> base;
|
Chris@16
|
70 public:
|
Chris@16
|
71 typedef select_first<StdPairRng> transform_fn_type;
|
Chris@16
|
72 typedef const StdPairRng source_range_type;
|
Chris@16
|
73
|
Chris@16
|
74 select_first_range(transform_fn_type fn, source_range_type& rng)
|
Chris@16
|
75 : base(fn, rng)
|
Chris@16
|
76 {
|
Chris@16
|
77 }
|
Chris@16
|
78
|
Chris@16
|
79 select_first_range(const base& other) : base(other) {}
|
Chris@16
|
80 };
|
Chris@16
|
81
|
Chris@16
|
82 template<class StdPairRng>
|
Chris@16
|
83 class select_second_mutable_range
|
Chris@16
|
84 : public transformed_range<
|
Chris@16
|
85 select_second_mutable<StdPairRng>,
|
Chris@16
|
86 StdPairRng>
|
Chris@16
|
87 {
|
Chris@16
|
88 typedef transformed_range<select_second_mutable<StdPairRng>, StdPairRng> base;
|
Chris@16
|
89 public:
|
Chris@16
|
90 typedef select_second_mutable<StdPairRng> transform_fn_type;
|
Chris@16
|
91 typedef StdPairRng source_range_type;
|
Chris@16
|
92
|
Chris@16
|
93 select_second_mutable_range(transform_fn_type fn, source_range_type& rng)
|
Chris@16
|
94 : base(fn, rng)
|
Chris@16
|
95 {
|
Chris@16
|
96 }
|
Chris@16
|
97
|
Chris@16
|
98 select_second_mutable_range(const base& other) : base(other) {}
|
Chris@16
|
99 };
|
Chris@16
|
100
|
Chris@16
|
101 template<class StdPairRng>
|
Chris@16
|
102 class select_second_const_range
|
Chris@16
|
103 : public transformed_range<
|
Chris@16
|
104 select_second_const<StdPairRng>,
|
Chris@16
|
105 const StdPairRng>
|
Chris@16
|
106 {
|
Chris@16
|
107 typedef transformed_range<select_second_const<StdPairRng>, const StdPairRng> base;
|
Chris@16
|
108 public:
|
Chris@16
|
109 typedef select_second_const<StdPairRng> transform_fn_type;
|
Chris@16
|
110 typedef const StdPairRng source_range_type;
|
Chris@16
|
111
|
Chris@16
|
112 select_second_const_range(transform_fn_type fn, source_range_type& rng)
|
Chris@16
|
113 : base(fn, rng)
|
Chris@16
|
114 {
|
Chris@16
|
115 }
|
Chris@16
|
116
|
Chris@16
|
117 select_second_const_range(const base& other) : base(other) {}
|
Chris@16
|
118 };
|
Chris@16
|
119
|
Chris@16
|
120 template< class StdPairRng >
|
Chris@16
|
121 inline select_first_range<StdPairRng>
|
Chris@16
|
122 operator|( const StdPairRng& r, map_keys_forwarder )
|
Chris@16
|
123 {
|
Chris@101
|
124 BOOST_RANGE_CONCEPT_ASSERT((
|
Chris@101
|
125 SinglePassRangeConcept<const StdPairRng>));
|
Chris@101
|
126
|
Chris@16
|
127 return operator|( r,
|
Chris@16
|
128 boost::adaptors::transformed( select_first<StdPairRng>() ) );
|
Chris@16
|
129 }
|
Chris@16
|
130
|
Chris@16
|
131 template< class StdPairRng >
|
Chris@16
|
132 inline select_second_mutable_range<StdPairRng>
|
Chris@16
|
133 operator|( StdPairRng& r, map_values_forwarder )
|
Chris@16
|
134 {
|
Chris@101
|
135 BOOST_RANGE_CONCEPT_ASSERT((SinglePassRangeConcept<StdPairRng>));
|
Chris@101
|
136
|
Chris@16
|
137 return operator|( r,
|
Chris@16
|
138 boost::adaptors::transformed( select_second_mutable<StdPairRng>() ) );
|
Chris@16
|
139 }
|
Chris@16
|
140
|
Chris@16
|
141 template< class StdPairRng >
|
Chris@16
|
142 inline select_second_const_range<StdPairRng>
|
Chris@16
|
143 operator|( const StdPairRng& r, map_values_forwarder )
|
Chris@16
|
144 {
|
Chris@101
|
145 BOOST_RANGE_CONCEPT_ASSERT((
|
Chris@101
|
146 SinglePassRangeConcept<const StdPairRng>));
|
Chris@101
|
147
|
Chris@16
|
148 return operator|( r,
|
Chris@16
|
149 boost::adaptors::transformed( select_second_const<StdPairRng>() ) );
|
Chris@16
|
150 }
|
Chris@16
|
151
|
Chris@16
|
152 } // 'range_detail'
|
Chris@16
|
153
|
Chris@16
|
154 using range_detail::select_first_range;
|
Chris@16
|
155 using range_detail::select_second_mutable_range;
|
Chris@16
|
156 using range_detail::select_second_const_range;
|
Chris@16
|
157
|
Chris@16
|
158 namespace adaptors
|
Chris@16
|
159 {
|
Chris@16
|
160 namespace
|
Chris@16
|
161 {
|
Chris@16
|
162 const range_detail::map_keys_forwarder map_keys =
|
Chris@16
|
163 range_detail::map_keys_forwarder();
|
Chris@16
|
164
|
Chris@16
|
165 const range_detail::map_values_forwarder map_values =
|
Chris@16
|
166 range_detail::map_values_forwarder();
|
Chris@16
|
167 }
|
Chris@16
|
168
|
Chris@16
|
169 template<class StdPairRange>
|
Chris@16
|
170 inline select_first_range<StdPairRange>
|
Chris@16
|
171 keys(const StdPairRange& rng)
|
Chris@16
|
172 {
|
Chris@101
|
173 BOOST_RANGE_CONCEPT_ASSERT((
|
Chris@101
|
174 SinglePassRangeConcept<const StdPairRange>));
|
Chris@101
|
175
|
Chris@16
|
176 return select_first_range<StdPairRange>(
|
Chris@16
|
177 range_detail::select_first<StdPairRange>(), rng );
|
Chris@16
|
178 }
|
Chris@16
|
179
|
Chris@16
|
180 template<class StdPairRange>
|
Chris@16
|
181 inline select_second_const_range<StdPairRange>
|
Chris@16
|
182 values(const StdPairRange& rng)
|
Chris@16
|
183 {
|
Chris@101
|
184 BOOST_RANGE_CONCEPT_ASSERT((
|
Chris@101
|
185 SinglePassRangeConcept<const StdPairRange>));
|
Chris@101
|
186
|
Chris@16
|
187 return select_second_const_range<StdPairRange>(
|
Chris@16
|
188 range_detail::select_second_const<StdPairRange>(), rng );
|
Chris@16
|
189 }
|
Chris@16
|
190
|
Chris@16
|
191 template<class StdPairRange>
|
Chris@16
|
192 inline select_second_mutable_range<StdPairRange>
|
Chris@16
|
193 values(StdPairRange& rng)
|
Chris@16
|
194 {
|
Chris@101
|
195 BOOST_RANGE_CONCEPT_ASSERT((SinglePassRangeConcept<StdPairRange>));
|
Chris@101
|
196
|
Chris@16
|
197 return select_second_mutable_range<StdPairRange>(
|
Chris@16
|
198 range_detail::select_second_mutable<StdPairRange>(), rng );
|
Chris@16
|
199 }
|
Chris@16
|
200 } // 'adaptors'
|
Chris@16
|
201
|
Chris@16
|
202 }
|
Chris@16
|
203
|
Chris@16
|
204 #endif
|