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 https://web.archive.org/web/20071014014301/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