]>
git.proxmox.com Git - ceph.git/blob - ceph/src/boost/libs/bimap/example/bimap_and_boost/assign.cpp
3 // Copyright (c) 2006-2007 Matias Capeletto
5 // Distributed under the Boost Software License, Version 1.0.
6 // (See accompanying file LICENSE_1_0.txt or copy at
7 // http://www.boost.org/LICENSE_1_0.txt)
9 // VC++ 8.0 warns on usage of certain Standard Library and API functions that
10 // can be cause buffer overruns or other possible security issues if misused.
11 // See http://msdn.microsoft.com/msdnmag/issues/05/05/SafeCandC/default.aspx
12 // But the wording of the warning is misleading and unsettling, there are no
13 // portable alternative functions, and VC++ 8.0's own libraries use the
14 // functions in question. So turn off the warnings.
15 #define _CRT_SECURE_NO_DEPRECATE
16 #define _SCL_SECURE_NO_DEPRECATE
18 // Boost.Bimap Example
19 //-----------------------------------------------------------------------------
21 #include <boost/config.hpp>
25 #include <boost/assign/list_of.hpp>
26 #include <boost/assign/list_inserter.hpp>
28 #include <boost/bimap/bimap.hpp>
29 #include <boost/bimap/multiset_of.hpp>
30 #include <boost/bimap/list_of.hpp>
32 using namespace boost::bimaps
;
33 using namespace boost
;
38 //[ code_bimap_and_boost_assign
40 typedef bimap
< multiset_of
< int >, list_of
< std::string
> > bm_type
;
42 // We can use assign::list_of to initialize the container.
44 bm_type bm
= assign::list_of
< bm_type::relation
> /*<
45 Note that `bm_type::relation` has to be used instead of `bm_type::value_type`.
46 Contrary to `value_type`, `relation` type stores the elements as non const, a
47 requirement of `assign::list_of` >*/
52 // The left map view is a multiset, again we use insert
54 assign::insert( bm
.left
)
59 // The right map view is a list so we use push_back here
60 // Note the order of the elements in the list!
62 assign::push_back( bm
.right
)
66 assign::push_front( bm
.right
)
71 // Since it is left_based the main view is a multiset, so we use insert