// Copyright Sebastian Ramacher, 2007. | |
// 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) | |
#ifndef BOOST_PTR_CONTAINER_DETAIL_SERIALIZE_PTR_MAP_ADAPTER_HPP | |
#define BOOST_PTR_CONTAINER_DETAIL_SERIALIZE_PTR_MAP_ADAPTER_HPP | |
#include <boost/ptr_container/ptr_map_adapter.hpp> | |
#include <boost/ptr_container/detail/serialize_xml_names.hpp> | |
#include <boost/serialization/split_free.hpp> | |
#include <boost/serialization/nvp.hpp> | |
namespace boost | |
{ | |
namespace serialization | |
{ | |
template<class Archive, class T, class VoidPtrMap, class CloneAllocator, bool Ordered> | |
void save(Archive& ar, const ptr_container_detail::ptr_map_adapter_base<T, VoidPtrMap, CloneAllocator,Ordered>& c, unsigned int /*version*/) | |
{ | |
typedef ptr_container_detail::ptr_map_adapter_base<T, VoidPtrMap, CloneAllocator,Ordered> container; | |
typedef BOOST_DEDUCED_TYPENAME container::const_iterator const_iterator; | |
ar << boost::serialization::make_nvp( ptr_container_detail::count(), | |
ptr_container_detail::serialize_as_const(c.size()) ); | |
const_iterator i = c.begin(), e = c.end(); | |
for(; i != e; ++i) | |
{ | |
ar << boost::serialization::make_nvp( ptr_container_detail::first(), i->first ); | |
ar << boost::serialization::make_nvp( ptr_container_detail::second(), | |
ptr_container_detail::serialize_as_const(i->second) ); | |
} | |
} | |
template<class Archive, class T, class VoidPtrMap, class CloneAllocator, bool Ordered> | |
void load(Archive& ar, ptr_map_adapter<T, VoidPtrMap, CloneAllocator,Ordered>& c, unsigned int /*version*/) | |
{ | |
typedef ptr_map_adapter<T, VoidPtrMap, CloneAllocator,Ordered> container; | |
typedef BOOST_DEDUCED_TYPENAME container::key_type key_type; | |
typedef BOOST_DEDUCED_TYPENAME container::size_type size_type; | |
typedef BOOST_DEDUCED_TYPENAME container::iterator iterator; | |
c.clear(); | |
size_type n; | |
ar >> boost::serialization::make_nvp( ptr_container_detail::count(), n ); | |
for(size_type i = 0u; i != n; ++i) | |
{ | |
key_type key; | |
T* value; | |
ar >> boost::serialization::make_nvp( ptr_container_detail::first(), key ); | |
ar >> boost::serialization::make_nvp( ptr_container_detail::second(), value ); | |
std::pair<iterator, bool> p = c.insert(key, value); | |
ar.reset_object_address(&p.first->first, &key); | |
} | |
} | |
template<class Archive, class T, class VoidPtrMap, class CloneAllocator, bool Ordered> | |
void load(Archive& ar, ptr_multimap_adapter<T, VoidPtrMap, CloneAllocator,Ordered>& c, unsigned int /*version*/) | |
{ | |
typedef ptr_multimap_adapter<T, VoidPtrMap, CloneAllocator,Ordered> container; | |
typedef BOOST_DEDUCED_TYPENAME container::key_type key_type; | |
typedef BOOST_DEDUCED_TYPENAME container::size_type size_type; | |
typedef BOOST_DEDUCED_TYPENAME container::iterator iterator; | |
c.clear(); | |
size_type n; | |
ar >> boost::serialization::make_nvp( ptr_container_detail::count(), n ); | |
for(size_type i = 0u; i != n; ++i) | |
{ | |
key_type key; | |
T* value; | |
ar >> boost::serialization::make_nvp( ptr_container_detail::first(), key ); | |
ar >> boost::serialization::make_nvp( ptr_container_detail::second(), value ); | |
iterator p = c.insert(key, value); | |
ar.reset_object_address(&p->first, &key); | |
} | |
} | |
} // namespace serialization | |
} // namespace boost | |
#endif |