// Boost.Bimap // // Copyright (c) 2006-2007 Matias Capeletto // // Distributed under 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) // VC++ 8.0 warns on usage of certain Standard Library and API functions that // can be cause buffer overruns or other possible security issues if misused. // See http://msdn.microsoft.com/msdnmag/issues/05/05/SafeCandC/default.aspx // But the wording of the warning is misleading and unsettling, there are no // portable alternative functions, and VC++ 8.0's own libraries use the // functions in question. So turn off the warnings. #define _CRT_SECURE_NO_DEPRECATE #define _SCL_SECURE_NO_DEPRECATE #include // Boost.Test #include #include #include #include #include int test_bimap_info() { using namespace boost::bimaps; typedef bimap< double, unordered_set_of, with_info > bm_type; bm_type bm; const bm_type & cbm = bm; // Insertion with info bm .insert( bm_type:: value_type(1.1 , 1, "one" ) ); bm.left .insert( bm_type:: left_value_type(2.2 , 2, "two" ) ); bm.right.insert( bm_type::right_value_type( 3 , 3.3, "three" ) ); bm.begin()->info = "1"; BOOST_CHECK( bm.right.find(1)->info == "1" ); bm.left.find(2.2)->info = "2"; BOOST_CHECK( bm.right.find(2)->info == "2" ); bm.right.find(3)->info = "3"; BOOST_CHECK( bm.right.find(3)->info == "3" ); // Empty info insert bm .insert( bm_type:: value_type(4.4 , 4) ); bm. left.insert( bm_type:: left_value_type(5.5 , 5) ); bm.right.insert( bm_type::right_value_type( 6 , 6.6) ); BOOST_CHECK( bm.right.find(4)->info == "" ); bm.left.info_at(4.4) = "4"; BOOST_CHECK( bm.right.info_at(4) == "4" ); BOOST_CHECK( cbm.right.info_at(4) == "4" ); bm.right.info_at(5) = "5"; BOOST_CHECK( bm.left.info_at(5.5) == "5" ); BOOST_CHECK( cbm.left.info_at(5.5) == "5" ); return 0; } struct left {}; struct right {}; struct info {}; int test_tagged_bimap_info() { using namespace boost::bimaps; typedef bimap< tagged, tagged, with_info > > bm_type; bm_type bm; const bm_type & cbm = bm; bm .insert( bm_type:: value_type(1,1,1) ); bm.left .insert( bm_type:: left_value_type(2,2,2) ); bm.right.insert( bm_type::right_value_type(3,3,3) ); bm.begin()->get() = 10; BOOST_CHECK( bm.right.find(1)->get() == 10 ); BOOST_CHECK( cbm.right.find(1)->get() == 10 ); bm.left.find(2)->get() = 20; BOOST_CHECK( bm.right.find(2)->get() == 20 ); BOOST_CHECK( cbm.right.find(2)->get() == 20 ); bm.right.find(3)->get() = 30; BOOST_CHECK( bm.right.find(3)->get() == 30 ); BOOST_CHECK( cbm.right.find(3)->get() == 30 ); // Empty info insert bm .insert( bm_type:: value_type(4,4) ); bm. left.insert( bm_type:: left_value_type(5,5) ); bm.right.insert( bm_type::right_value_type(6,6) ); bm.left.info_at(4) = 4; BOOST_CHECK( bm.right.info_at(4) == 4 ); BOOST_CHECK( cbm.right.info_at(4) == 4 ); bm.right.info_at(5) = 5; BOOST_CHECK( bm.left.info_at(5) == 5 ); BOOST_CHECK( cbm.left.info_at(5) == 5 ); return 0; } int test_main( int, char* [] ) { test_bimap_info(); test_tagged_bimap_info(); return 0; }