#ifndef BOOST_SERIALIZATION_MAP_HPP #define BOOST_SERIALIZATION_MAP_HPP // MS compatible compilers support #pragma once #if defined(_MSC_VER) # pragma once #endif /////////1/////////2/////////3/////////4/////////5/////////6/////////7/////////8 // serialization/map.hpp: // serialization for stl map templates // (C) Copyright 2002-2014 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) // See http://www.boost.org for updates, documentation, and revision history. #include #include #include #include #include #include #include #include #include #include #include #include namespace boost { namespace serialization { ////////1/////////2/////////3/////////4/////////5/////////6/////////7/////////8 // implementation of serialization for map and mult-map STL containers template inline void load_map_collection(Archive & ar, Container &s) { s.clear(); const boost::serialization::library_version_type library_version( ar.get_library_version() ); // retrieve number of elements item_version_type item_version(0); collection_size_type count; ar >> BOOST_SERIALIZATION_NVP(count); if(boost::serialization::library_version_type(3) < library_version){ ar >> BOOST_SERIALIZATION_NVP(item_version); } typename Container::iterator hint; hint = s.begin(); while(count-- > 0){ typedef typename Container::value_type type; detail::stack_construct t(ar, item_version); ar >> boost::serialization::make_nvp("item", t.reference()); typename Container::iterator result = s.insert(hint, boost::move(t.reference())); ar.reset_object_address(& (result->second), & t.reference().second); hint = result; ++hint; } } // map template inline void save( Archive & ar, const std::map &t, const unsigned int /* file_version */ ){ boost::serialization::stl::save_collection< Archive, std::map >(ar, t); } template inline void load( Archive & ar, std::map &t, const unsigned int /* file_version */ ){ load_map_collection(ar, t); } // split non-intrusive serialization function member into separate // non intrusive save/load member functions template inline void serialize( Archive & ar, std::map &t, const unsigned int file_version ){ boost::serialization::split_free(ar, t, file_version); } // multimap template inline void save( Archive & ar, const std::multimap &t, const unsigned int /* file_version */ ){ boost::serialization::stl::save_collection< Archive, std::multimap >(ar, t); } template inline void load( Archive & ar, std::multimap &t, const unsigned int /* file_version */ ){ load_map_collection(ar, t); } // split non-intrusive serialization function member into separate // non intrusive save/load member functions template inline void serialize( Archive & ar, std::multimap &t, const unsigned int file_version ){ boost::serialization::split_free(ar, t, file_version); } } // serialization } // namespace boost #endif // BOOST_SERIALIZATION_MAP_HPP