/////////1/////////2/////////3/////////4/////////5/////////6/////////7/////////8 // test_map.cpp // (C) Copyright 2002 Robert Ramey - http://www.rrsd.com . // Use, modification and distribution is subject to 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) // should pass compilation and execution #include #include #include #include // size_t #include #include #include #if defined(BOOST_NO_STDC_NAMESPACE) namespace std{ using ::rand; using ::size_t; } #endif #include "test_tools.hpp" #include #include BOOST_PP_STRINGIZE(BOOST_ARCHIVE_TEST) #include #include #include "A.hpp" /////////////////////////////////////////////////////// // a key value initialized with a random value for use // in testing STL map serialization struct random_key { friend class boost::serialization::access; template void serialize( Archive & ar, const unsigned int /* file_version */ ){ ar & boost::serialization::make_nvp("random_key", m_i); } int m_i; random_key() : m_i(std::rand()){}; bool operator<(const random_key &rhs) const { return m_i < rhs.m_i; } bool operator==(const random_key &rhs) const { return m_i == rhs.m_i; } operator std::size_t () const { // required by hash_map return m_i; } }; BOOST_BROKEN_COMPILER_TYPE_TRAITS_SPECIALIZATION(random_key) void test_map(){ const char * testfile = boost::archive::tmpnam(NULL); BOOST_REQUIRE(NULL != testfile); BOOST_CHECKPOINT("map"); // test map of objects std::map amap; amap.insert(std::make_pair(random_key(), A())); amap.insert(std::make_pair(random_key(), A())); { test_ostream os(testfile, TEST_STREAM_FLAGS); test_oarchive oa(os); oa << boost::serialization::make_nvp("amap", amap); } std::map amap1; { test_istream is(testfile, TEST_STREAM_FLAGS); test_iarchive ia(is); ia >> boost::serialization::make_nvp("amap", amap1); } BOOST_CHECK(amap == amap1); std::remove(testfile); } void test_map_2(){ const char * testfile = boost::archive::tmpnam(NULL); BOOST_REQUIRE(NULL != testfile); BOOST_CHECKPOINT("map_2"); std::pair a(11, 22); std::map b; b[0] = 0; b[-1] = -1; b[1] = 1; { test_ostream os(testfile, TEST_STREAM_FLAGS); std::pair * const pa = &a; std::map * const pb = &b; test_oarchive oa(os); oa << BOOST_SERIALIZATION_NVP(pb); oa << BOOST_SERIALIZATION_NVP(pa); } { test_istream is(testfile, TEST_STREAM_FLAGS); std::pair *pa = 0; std::map *pb = 0; test_iarchive ia(is); ia >> BOOST_SERIALIZATION_NVP(pb); ia >> BOOST_SERIALIZATION_NVP(pa); delete pa; delete pb; } std::remove(testfile); } void test_multimap(){ const char * testfile = boost::archive::tmpnam(NULL); BOOST_REQUIRE(NULL != testfile); BOOST_CHECKPOINT("multimap"); std::multimap amultimap; amultimap.insert(std::make_pair(random_key(), A())); amultimap.insert(std::make_pair(random_key(), A())); { test_ostream os(testfile, TEST_STREAM_FLAGS); test_oarchive oa(os); oa << boost::serialization::make_nvp("amultimap", amultimap); } std::multimap amultimap1; { test_istream is(testfile, TEST_STREAM_FLAGS); test_iarchive ia(is); ia >> boost::serialization::make_nvp("amultimap", amultimap1); } BOOST_CHECK(amultimap == amultimap1); std::remove(testfile); } #ifdef BOOST_HAS_HASH #include /* #if defined(__SGI_STL_PORT) || defined(_STLPORT_VERSION) #define STD _STLP_STD #else #define STD BOOST_STD_EXTENSION_NAMESPACE #endif */ namespace BOOST_STD_EXTENSION_NAMESPACE { template<> struct hash{ std::size_t operator()(const random_key& r) const { return (std::size_t)r; } }; } // namespace BOOST_STD_EXTENSION_NAMESPACE void test_hash_map(){ const char * testfile = boost::archive::tmpnam(NULL); BOOST_REQUIRE(NULL != testfile); BOOST_CHECKPOINT("hash_map"); // test hash_map of objects BOOST_STD_EXTENSION_NAMESPACE::hash_map ahash_map; ahash_map.insert(std::make_pair(random_key(), A())); ahash_map.insert(std::make_pair(random_key(), A())); { test_ostream os(testfile, TEST_STREAM_FLAGS); test_oarchive oa(os); oa << boost::serialization::make_nvp("ahashmap",ahash_map); } BOOST_STD_EXTENSION_NAMESPACE::hash_map ahash_map1; { test_istream is(testfile, TEST_STREAM_FLAGS); test_iarchive ia(is); ia >> boost::serialization::make_nvp("ahashmap",ahash_map1); } BOOST_CHECK(ahash_map == ahash_map1); std::remove(testfile); } void test_hash_multimap(){ const char * testfile = boost::archive::tmpnam(NULL); BOOST_REQUIRE(NULL != testfile); BOOST_CHECKPOINT("hash_multimap"); BOOST_STD_EXTENSION_NAMESPACE::hash_multimap ahash_multimap; ahash_multimap.insert(std::make_pair(random_key(), A())); ahash_multimap.insert(std::make_pair(random_key(), A())); { test_ostream os(testfile, TEST_STREAM_FLAGS); test_oarchive oa(os); oa << boost::serialization::make_nvp("ahash_multimap", ahash_multimap); } BOOST_STD_EXTENSION_NAMESPACE::hash_multimap ahash_multimap1; { test_istream is(testfile, TEST_STREAM_FLAGS); test_iarchive ia(is); ia >> boost::serialization::make_nvp("ahash_multimap", ahash_multimap1); } BOOST_CHECK(ahash_multimap == ahash_multimap1); std::remove(testfile); } #endif int test_main( int /* argc */, char* /* argv */[] ) { test_map(); test_map_2(); test_multimap(); #ifdef BOOST_HAS_HASH test_hash_map(); test_hash_multimap(); #endif return EXIT_SUCCESS; }