Chris@16
|
1 // Boost.Bimap
|
Chris@16
|
2 //
|
Chris@16
|
3 // Copyright (c) 2006-2007 Matias Capeletto
|
Chris@16
|
4 //
|
Chris@16
|
5 // Distributed under the Boost Software License, Version 1.0.
|
Chris@16
|
6 // (See accompanying file LICENSE_1_0.txt or copy at
|
Chris@16
|
7 // http://www.boost.org/LICENSE_1_0.txt)
|
Chris@16
|
8
|
Chris@16
|
9 /// \file views/vector_set_view.hpp
|
Chris@16
|
10 /// \brief View of a side of a bimap that is signature compatible with std::vector.
|
Chris@16
|
11
|
Chris@16
|
12 #ifndef BOOST_BIMAP_VIEWS_VECTOR_SET_VIEW_HPP
|
Chris@16
|
13 #define BOOST_BIMAP_VIEWS_VECTOR_SET_VIEW_HPP
|
Chris@16
|
14
|
Chris@101
|
15 #if defined(_MSC_VER)
|
Chris@16
|
16 #pragma once
|
Chris@16
|
17 #endif
|
Chris@16
|
18
|
Chris@16
|
19 #include <boost/config.hpp>
|
Chris@16
|
20
|
Chris@16
|
21 #include <boost/bimap/container_adaptor/vector_adaptor.hpp>
|
Chris@16
|
22 #include <boost/bimap/container_adaptor/detail/comparison_adaptor.hpp>
|
Chris@16
|
23 #include <boost/bimap/detail/set_view_base.hpp>
|
Chris@16
|
24 #include <boost/bimap/detail/map_view_base.hpp>
|
Chris@16
|
25
|
Chris@16
|
26 namespace boost {
|
Chris@16
|
27 namespace bimaps {
|
Chris@16
|
28 namespace views {
|
Chris@16
|
29
|
Chris@16
|
30 /// \brief View of a bimap that is signature compatible with std::vector.
|
Chris@16
|
31 /**
|
Chris@16
|
32
|
Chris@16
|
33 This class uses container_adaptor and iterator_adaptor to wrapped a index of the
|
Chris@16
|
34 multi_index bimap core so it can be used as a std::vector.
|
Chris@16
|
35
|
Chris@16
|
36 See also const_set_view.
|
Chris@16
|
37 **/
|
Chris@16
|
38
|
Chris@16
|
39 template< class CoreIndex >
|
Chris@16
|
40 class vector_set_view
|
Chris@16
|
41 :
|
Chris@16
|
42 public BOOST_BIMAP_SEQUENCED_SET_VIEW_CONTAINER_ADAPTOR(
|
Chris@16
|
43 vector_adaptor,
|
Chris@16
|
44 CoreIndex,
|
Chris@16
|
45 reverse_iterator, const_reverse_iterator
|
Chris@16
|
46 ),
|
Chris@16
|
47
|
Chris@16
|
48 public ::boost::bimaps::detail::
|
Chris@16
|
49 set_view_base< vector_set_view< CoreIndex >, CoreIndex >
|
Chris@16
|
50 {
|
Chris@16
|
51 BOOST_BIMAP_SET_VIEW_BASE_FRIEND(vector_set_view,CoreIndex)
|
Chris@16
|
52
|
Chris@16
|
53 typedef BOOST_BIMAP_SEQUENCED_SET_VIEW_CONTAINER_ADAPTOR(
|
Chris@16
|
54 vector_adaptor,
|
Chris@16
|
55 CoreIndex,
|
Chris@16
|
56 reverse_iterator, const_reverse_iterator
|
Chris@16
|
57
|
Chris@16
|
58 ) base_;
|
Chris@16
|
59
|
Chris@16
|
60 public:
|
Chris@16
|
61
|
Chris@16
|
62 vector_set_view(BOOST_DEDUCED_TYPENAME base_::base_type & c) :
|
Chris@16
|
63 base_(c) {}
|
Chris@16
|
64
|
Chris@16
|
65 vector_set_view & operator=(const vector_set_view & v)
|
Chris@16
|
66 {
|
Chris@16
|
67 this->base() = v.base();
|
Chris@16
|
68 return *this;
|
Chris@16
|
69 }
|
Chris@16
|
70
|
Chris@16
|
71 BOOST_DEDUCED_TYPENAME base_::const_reference
|
Chris@16
|
72 operator[](BOOST_DEDUCED_TYPENAME base_::size_type n) const
|
Chris@16
|
73 {
|
Chris@16
|
74 return this->template functor<BOOST_DEDUCED_TYPENAME base_::value_from_base>()(
|
Chris@16
|
75 this->base().operator[](n)
|
Chris@16
|
76 );
|
Chris@16
|
77 }
|
Chris@16
|
78
|
Chris@16
|
79 BOOST_DEDUCED_TYPENAME base_::const_reference
|
Chris@16
|
80 at(BOOST_DEDUCED_TYPENAME base_::size_type n) const
|
Chris@16
|
81 {
|
Chris@16
|
82 return this->template functor<BOOST_DEDUCED_TYPENAME base_::value_from_base>()(
|
Chris@16
|
83 this->base().at(n)
|
Chris@16
|
84 );
|
Chris@16
|
85 }
|
Chris@16
|
86
|
Chris@16
|
87 BOOST_DEDUCED_TYPENAME base_::reference
|
Chris@16
|
88 operator[](BOOST_DEDUCED_TYPENAME base_::size_type n)
|
Chris@16
|
89 {
|
Chris@16
|
90 return this->template functor<BOOST_DEDUCED_TYPENAME base_::value_from_base>()(
|
Chris@16
|
91 const_cast<BOOST_DEDUCED_TYPENAME base_::base_type::value_type &>(
|
Chris@16
|
92 this->base().operator[](n)
|
Chris@16
|
93 ));
|
Chris@16
|
94 }
|
Chris@16
|
95
|
Chris@16
|
96 BOOST_DEDUCED_TYPENAME base_::reference
|
Chris@16
|
97 at(BOOST_DEDUCED_TYPENAME base_::size_type n)
|
Chris@16
|
98 {
|
Chris@16
|
99 return this->template functor<BOOST_DEDUCED_TYPENAME base_::value_from_base>()(
|
Chris@16
|
100 const_cast<BOOST_DEDUCED_TYPENAME base_::base_type::value_type &>(
|
Chris@16
|
101 this->base().at(n)
|
Chris@16
|
102 ));
|
Chris@16
|
103 }
|
Chris@16
|
104
|
Chris@16
|
105 BOOST_BIMAP_VIEW_ASSIGN_IMPLEMENTATION(base_)
|
Chris@16
|
106
|
Chris@16
|
107 BOOST_BIMAP_VIEW_FRONT_BACK_IMPLEMENTATION(base_)
|
Chris@16
|
108
|
Chris@16
|
109 // List operations
|
Chris@16
|
110
|
Chris@16
|
111 void splice(BOOST_DEDUCED_TYPENAME base_::iterator position,
|
Chris@16
|
112 vector_set_view & x)
|
Chris@16
|
113 {
|
Chris@16
|
114 this->base().splice(
|
Chris@16
|
115 this->template functor<
|
Chris@16
|
116 BOOST_DEDUCED_TYPENAME base_::iterator_to_base>()(position),
|
Chris@16
|
117 x.base()
|
Chris@16
|
118 );
|
Chris@16
|
119 }
|
Chris@16
|
120
|
Chris@16
|
121 void splice(BOOST_DEDUCED_TYPENAME base_::iterator position,
|
Chris@16
|
122 vector_set_view & x,
|
Chris@16
|
123 BOOST_DEDUCED_TYPENAME base_::iterator i)
|
Chris@16
|
124 {
|
Chris@16
|
125 this->base().splice(
|
Chris@16
|
126 this->template functor<
|
Chris@16
|
127 BOOST_DEDUCED_TYPENAME base_::iterator_to_base>()(position),
|
Chris@16
|
128 x.base(),
|
Chris@16
|
129 this->template functor<
|
Chris@16
|
130 BOOST_DEDUCED_TYPENAME base_::iterator_to_base>()(i)
|
Chris@16
|
131 );
|
Chris@16
|
132 }
|
Chris@16
|
133
|
Chris@16
|
134 void splice(BOOST_DEDUCED_TYPENAME base_::iterator position,
|
Chris@16
|
135 vector_set_view & x,
|
Chris@16
|
136 BOOST_DEDUCED_TYPENAME base_::iterator first,
|
Chris@16
|
137 BOOST_DEDUCED_TYPENAME base_::iterator last)
|
Chris@16
|
138 {
|
Chris@16
|
139 this->base().splice(
|
Chris@16
|
140 this->template functor<
|
Chris@16
|
141 BOOST_DEDUCED_TYPENAME base_::iterator_to_base>()(position),
|
Chris@16
|
142 x.base(),
|
Chris@16
|
143 this->template functor<
|
Chris@16
|
144 BOOST_DEDUCED_TYPENAME base_::iterator_to_base>()(first),
|
Chris@16
|
145 this->template functor<
|
Chris@16
|
146 BOOST_DEDUCED_TYPENAME base_::iterator_to_base>()(last)
|
Chris@16
|
147 );
|
Chris@16
|
148 }
|
Chris@16
|
149
|
Chris@16
|
150 void remove(BOOST_DEDUCED_TYPENAME ::boost::call_traits<
|
Chris@16
|
151 BOOST_DEDUCED_TYPENAME base_::value_type >::param_type value)
|
Chris@16
|
152 {
|
Chris@16
|
153 this->base().remove(
|
Chris@16
|
154 this->template functor<
|
Chris@16
|
155 BOOST_DEDUCED_TYPENAME base_::value_to_base>()(value)
|
Chris@16
|
156 );
|
Chris@16
|
157 }
|
Chris@16
|
158
|
Chris@16
|
159 template<typename Predicate>
|
Chris@16
|
160 void remove_if(Predicate pred)
|
Chris@16
|
161 {
|
Chris@16
|
162 this->base().remove_if(
|
Chris@16
|
163 ::boost::bimaps::container_adaptor::detail::unary_check_adaptor
|
Chris@16
|
164 <
|
Chris@16
|
165 Predicate,
|
Chris@16
|
166 BOOST_DEDUCED_TYPENAME base_::base_type::value_type,
|
Chris@16
|
167 BOOST_DEDUCED_TYPENAME base_::value_from_base
|
Chris@16
|
168
|
Chris@16
|
169 >( pred, this->template functor<
|
Chris@16
|
170 BOOST_DEDUCED_TYPENAME base_::value_from_base>() )
|
Chris@16
|
171 );
|
Chris@16
|
172 }
|
Chris@16
|
173
|
Chris@16
|
174 void unique()
|
Chris@16
|
175 {
|
Chris@16
|
176 this->base().unique(
|
Chris@16
|
177 ::boost::bimaps::container_adaptor::detail::comparison_adaptor
|
Chris@16
|
178 <
|
Chris@16
|
179 std::equal_to<BOOST_DEDUCED_TYPENAME base_::value_type>,
|
Chris@16
|
180 BOOST_DEDUCED_TYPENAME base_::base_type::value_type,
|
Chris@16
|
181 BOOST_DEDUCED_TYPENAME base_::value_from_base
|
Chris@16
|
182
|
Chris@16
|
183 >(
|
Chris@16
|
184 std::equal_to<BOOST_DEDUCED_TYPENAME base_::value_type>(),
|
Chris@16
|
185 this->template functor<
|
Chris@16
|
186 BOOST_DEDUCED_TYPENAME base_::value_from_base>()
|
Chris@16
|
187 )
|
Chris@16
|
188 );
|
Chris@16
|
189 }
|
Chris@16
|
190
|
Chris@16
|
191 template< class BinaryPredicate >
|
Chris@16
|
192 void unique(BinaryPredicate binary_pred)
|
Chris@16
|
193 {
|
Chris@16
|
194 this->base().unique(
|
Chris@16
|
195 ::boost::bimaps::container_adaptor::detail::comparison_adaptor
|
Chris@16
|
196 <
|
Chris@16
|
197 BinaryPredicate,
|
Chris@16
|
198 BOOST_DEDUCED_TYPENAME base_::base_type::value_type,
|
Chris@16
|
199 BOOST_DEDUCED_TYPENAME base_::value_from_base
|
Chris@16
|
200
|
Chris@16
|
201 >( binary_pred,
|
Chris@16
|
202 this->template functor<
|
Chris@16
|
203 BOOST_DEDUCED_TYPENAME base_::value_from_base>()
|
Chris@16
|
204 )
|
Chris@16
|
205 );
|
Chris@16
|
206 }
|
Chris@16
|
207
|
Chris@16
|
208 void merge(vector_set_view & x)
|
Chris@16
|
209 {
|
Chris@16
|
210 this->base().merge(x.base(),
|
Chris@16
|
211 ::boost::bimaps::container_adaptor::detail::comparison_adaptor
|
Chris@16
|
212 <
|
Chris@16
|
213 std::less<BOOST_DEDUCED_TYPENAME base_::value_type>,
|
Chris@16
|
214 BOOST_DEDUCED_TYPENAME base_::base_type::value_type,
|
Chris@16
|
215 BOOST_DEDUCED_TYPENAME base_::value_from_base
|
Chris@16
|
216
|
Chris@16
|
217 >(
|
Chris@16
|
218 std::less<BOOST_DEDUCED_TYPENAME base_::value_type>(),
|
Chris@16
|
219 this->template functor<
|
Chris@16
|
220 BOOST_DEDUCED_TYPENAME base_::value_from_base>()
|
Chris@16
|
221 )
|
Chris@16
|
222 );
|
Chris@16
|
223 }
|
Chris@16
|
224
|
Chris@16
|
225 template< class Compare >
|
Chris@16
|
226 void merge(vector_set_view & x, Compare comp)
|
Chris@16
|
227 {
|
Chris@16
|
228 this->base().merge(x.base(),
|
Chris@16
|
229 ::boost::bimaps::container_adaptor::detail::comparison_adaptor
|
Chris@16
|
230 <
|
Chris@16
|
231 Compare,
|
Chris@16
|
232 BOOST_DEDUCED_TYPENAME base_::base_type::value_type,
|
Chris@16
|
233 BOOST_DEDUCED_TYPENAME base_::value_from_base
|
Chris@16
|
234
|
Chris@16
|
235 >( comp, this->template functor<
|
Chris@16
|
236 BOOST_DEDUCED_TYPENAME base_::value_from_base>() )
|
Chris@16
|
237 );
|
Chris@16
|
238 }
|
Chris@16
|
239
|
Chris@16
|
240 void sort()
|
Chris@16
|
241 {
|
Chris@16
|
242 this->base().sort(
|
Chris@16
|
243 ::boost::bimaps::container_adaptor::detail::comparison_adaptor
|
Chris@16
|
244 <
|
Chris@16
|
245 std::less<BOOST_DEDUCED_TYPENAME base_::value_type>,
|
Chris@16
|
246 BOOST_DEDUCED_TYPENAME base_::base_type::value_type,
|
Chris@16
|
247 BOOST_DEDUCED_TYPENAME base_::value_from_base
|
Chris@16
|
248
|
Chris@16
|
249 >(
|
Chris@16
|
250 std::less<BOOST_DEDUCED_TYPENAME base_::value_type>(),
|
Chris@16
|
251 this->template functor<
|
Chris@16
|
252 BOOST_DEDUCED_TYPENAME base_::value_from_base>()
|
Chris@16
|
253 )
|
Chris@16
|
254 );
|
Chris@16
|
255 }
|
Chris@16
|
256
|
Chris@16
|
257 template< class Compare >
|
Chris@16
|
258 void sort(Compare comp)
|
Chris@16
|
259 {
|
Chris@16
|
260 this->base().sort(
|
Chris@16
|
261 ::boost::bimaps::container_adaptor::detail::comparison_adaptor
|
Chris@16
|
262 <
|
Chris@16
|
263 Compare,
|
Chris@16
|
264 BOOST_DEDUCED_TYPENAME base_::base_type::value_type,
|
Chris@16
|
265 BOOST_DEDUCED_TYPENAME base_::value_from_base
|
Chris@16
|
266
|
Chris@16
|
267 >( comp, this->template functor<
|
Chris@16
|
268 BOOST_DEDUCED_TYPENAME base_::value_from_base>() )
|
Chris@16
|
269 );
|
Chris@16
|
270 }
|
Chris@16
|
271
|
Chris@16
|
272 void reverse()
|
Chris@16
|
273 {
|
Chris@16
|
274 this->base().reverse();
|
Chris@16
|
275 }
|
Chris@16
|
276
|
Chris@16
|
277 // Rearrange Operations
|
Chris@16
|
278
|
Chris@16
|
279 void relocate(BOOST_DEDUCED_TYPENAME base_::iterator position,
|
Chris@16
|
280 BOOST_DEDUCED_TYPENAME base_::iterator i)
|
Chris@16
|
281 {
|
Chris@16
|
282 this->base().relocate(
|
Chris@16
|
283 this->template functor<
|
Chris@16
|
284 BOOST_DEDUCED_TYPENAME base_::iterator_to_base>()(position),
|
Chris@16
|
285 this->template functor<
|
Chris@16
|
286 BOOST_DEDUCED_TYPENAME base_::iterator_to_base>()(i)
|
Chris@16
|
287 );
|
Chris@16
|
288 }
|
Chris@16
|
289
|
Chris@16
|
290 void relocate(BOOST_DEDUCED_TYPENAME base_::iterator position,
|
Chris@16
|
291 BOOST_DEDUCED_TYPENAME base_::iterator first,
|
Chris@16
|
292 BOOST_DEDUCED_TYPENAME base_::iterator last)
|
Chris@16
|
293 {
|
Chris@16
|
294 this->base().relocate(
|
Chris@16
|
295 this->template functor<
|
Chris@16
|
296 BOOST_DEDUCED_TYPENAME base_::iterator_to_base>()(position),
|
Chris@16
|
297 this->template functor<
|
Chris@16
|
298 BOOST_DEDUCED_TYPENAME base_::iterator_to_base>()(first),
|
Chris@16
|
299 this->template functor<
|
Chris@16
|
300 BOOST_DEDUCED_TYPENAME base_::iterator_to_base>()(last)
|
Chris@16
|
301 );
|
Chris@16
|
302 }
|
Chris@16
|
303
|
Chris@16
|
304 };
|
Chris@16
|
305
|
Chris@16
|
306
|
Chris@16
|
307 } // namespace views
|
Chris@16
|
308 } // namespace bimaps
|
Chris@16
|
309 } // namespace boost
|
Chris@16
|
310
|
Chris@16
|
311
|
Chris@16
|
312 #endif // BOOST_BIMAP_VIEWS_VECTOR_SET_VIEW_HPP
|
Chris@16
|
313
|