/////////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 #include #ifdef BOOST_HAS_HASH #include #endif #include "test_tools.hpp" #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; } }; #if defined(__LIBCOMO__) || (defined(__SGI_STL_PORT) || defined(_STLPORT_VERSION)) namespace std { template<> struct equal_to { bool operator()(const random_key& lhs, const random_key& rhs) const { return lhs.operator==(rhs); } }; } // namespace std 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 #endif int test_main( int /* argc */, char* /* argv */[] ) { 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); 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); #ifdef BOOST_HAS_HASH 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); } // at least one library - MSL notes: it doesn't make much sense // to implement the == operator for hash collections - but goes ahead // does it anyway even though it doesn't seem to work. So sort into // vectors and then compare. std::vector< std::pair > tvec, tvec1; std::copy(ahash_map.begin(), ahash_map.end(), std::back_inserter(tvec)); std::sort(tvec.begin(), tvec.end()); std::copy(ahash_map1.begin(), ahash_map1.end(), std::back_inserter(tvec1)); std::sort(tvec1.begin(), tvec1.end()); BOOST_CHECK(tvec == tvec1); 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); } // at least one library - MSL notes: it doesn't make much sense // to implement the == operator for hash collections - but goes ahead // does it anyway even though it doesn't seem to work. So sort into // vectors and then compare. tvec.clear(); tvec1.clear(); std::copy(ahash_multimap.begin(), ahash_multimap.end(), std::back_inserter(tvec)); std::sort(tvec.begin(), tvec.end()); std::copy(ahash_multimap1.begin(), ahash_multimap1.end(), std::back_inserter(tvec1)); std::sort(tvec1.begin(), tvec1.end()); BOOST_CHECK(tvec == tvec1); #endif std::remove(testfile); return boost::exit_success; } // EOF