232 lines
6.2 KiB
C++
232 lines
6.2 KiB
C++
#ifndef BOOST_SERIALIZATION_HASH_MAP_HPP
|
|
#define BOOST_SERIALIZATION_HASH_MAP_HPP
|
|
|
|
// MS compatible compilers support #pragma once
|
|
#if defined(_MSC_VER)
|
|
# pragma once
|
|
#endif
|
|
|
|
/////////1/////////2/////////3/////////4/////////5/////////6/////////7/////////8
|
|
// serialization/hash_map.hpp:
|
|
// serialization for stl hash_map templates
|
|
|
|
// (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)
|
|
|
|
// See http://www.boost.org for updates, documentation, and revision history.
|
|
|
|
#include <boost/config.hpp>
|
|
#ifdef BOOST_HAS_HASH
|
|
#include BOOST_HASH_MAP_HEADER
|
|
|
|
#include <boost/serialization/utility.hpp>
|
|
#include <boost/serialization/hash_collections_save_imp.hpp>
|
|
#include <boost/serialization/hash_collections_load_imp.hpp>
|
|
#include <boost/serialization/split_free.hpp>
|
|
|
|
namespace boost {
|
|
namespace serialization {
|
|
|
|
namespace stl {
|
|
|
|
// map input
|
|
template<class Archive, class Container>
|
|
struct archive_input_hash_map
|
|
{
|
|
inline void operator()(
|
|
Archive &ar,
|
|
Container &s,
|
|
const unsigned int v
|
|
){
|
|
typedef typename Container::value_type type;
|
|
detail::stack_construct<Archive, type> t(ar, v);
|
|
// borland fails silently w/o full namespace
|
|
ar >> boost::serialization::make_nvp("item", t.reference());
|
|
std::pair<typename Container::const_iterator, bool> result =
|
|
s.insert(t.reference());
|
|
// note: the following presumes that the map::value_type was NOT tracked
|
|
// in the archive. This is the usual case, but here there is no way
|
|
// to determine that.
|
|
if(result.second){
|
|
ar.reset_object_address(
|
|
& (result.first->second),
|
|
& t.reference().second
|
|
);
|
|
}
|
|
}
|
|
};
|
|
|
|
// multimap input
|
|
template<class Archive, class Container>
|
|
struct archive_input_hash_multimap
|
|
{
|
|
inline void operator()(
|
|
Archive &ar,
|
|
Container &s,
|
|
const unsigned int v
|
|
){
|
|
typedef typename Container::value_type type;
|
|
detail::stack_construct<Archive, type> t(ar, v);
|
|
// borland fails silently w/o full namespace
|
|
ar >> boost::serialization::make_nvp("item", t.reference());
|
|
typename Container::const_iterator result
|
|
= s.insert(t.reference());
|
|
// note: the following presumes that the map::value_type was NOT tracked
|
|
// in the archive. This is the usual case, but here there is no way
|
|
// to determine that.
|
|
ar.reset_object_address(
|
|
& result->second,
|
|
& t.reference()
|
|
);
|
|
}
|
|
};
|
|
|
|
} // stl
|
|
|
|
template<
|
|
class Archive,
|
|
class Key,
|
|
class HashFcn,
|
|
class EqualKey,
|
|
class Allocator
|
|
>
|
|
inline void save(
|
|
Archive & ar,
|
|
const BOOST_STD_EXTENSION_NAMESPACE::hash_map<
|
|
Key, HashFcn, EqualKey, Allocator
|
|
> &t,
|
|
const unsigned int file_version
|
|
){
|
|
boost::serialization::stl::save_hash_collection<
|
|
Archive,
|
|
BOOST_STD_EXTENSION_NAMESPACE::hash_map<
|
|
Key, HashFcn, EqualKey, Allocator
|
|
>
|
|
>(ar, t);
|
|
}
|
|
|
|
template<
|
|
class Archive,
|
|
class Key,
|
|
class HashFcn,
|
|
class EqualKey,
|
|
class Allocator
|
|
>
|
|
inline void load(
|
|
Archive & ar,
|
|
BOOST_STD_EXTENSION_NAMESPACE::hash_map<
|
|
Key, HashFcn, EqualKey, Allocator
|
|
> &t,
|
|
const unsigned int file_version
|
|
){
|
|
boost::serialization::stl::load_hash_collection<
|
|
Archive,
|
|
BOOST_STD_EXTENSION_NAMESPACE::hash_map<
|
|
Key, HashFcn, EqualKey, Allocator
|
|
>,
|
|
boost::serialization::stl::archive_input_hash_map<
|
|
Archive,
|
|
BOOST_STD_EXTENSION_NAMESPACE::hash_map<
|
|
Key, HashFcn, EqualKey, Allocator
|
|
>
|
|
>
|
|
>(ar, t);
|
|
}
|
|
|
|
// split non-intrusive serialization function member into separate
|
|
// non intrusive save/load member functions
|
|
template<
|
|
class Archive,
|
|
class Key,
|
|
class HashFcn,
|
|
class EqualKey,
|
|
class Allocator
|
|
>
|
|
inline void serialize(
|
|
Archive & ar,
|
|
BOOST_STD_EXTENSION_NAMESPACE::hash_map<
|
|
Key, HashFcn, EqualKey, Allocator
|
|
> &t,
|
|
const unsigned int file_version
|
|
){
|
|
boost::serialization::split_free(ar, t, file_version);
|
|
}
|
|
|
|
// hash_multimap
|
|
template<
|
|
class Archive,
|
|
class Key,
|
|
class HashFcn,
|
|
class EqualKey,
|
|
class Allocator
|
|
>
|
|
inline void save(
|
|
Archive & ar,
|
|
const BOOST_STD_EXTENSION_NAMESPACE::hash_multimap<
|
|
Key, HashFcn, EqualKey, Allocator
|
|
> &t,
|
|
const unsigned int file_version
|
|
){
|
|
boost::serialization::stl::save_hash_collection<
|
|
Archive,
|
|
BOOST_STD_EXTENSION_NAMESPACE::hash_multimap<
|
|
Key, HashFcn, EqualKey, Allocator
|
|
>
|
|
>(ar, t);
|
|
}
|
|
|
|
template<
|
|
class Archive,
|
|
class Key,
|
|
class HashFcn,
|
|
class EqualKey,
|
|
class Allocator
|
|
>
|
|
inline void load(
|
|
Archive & ar,
|
|
BOOST_STD_EXTENSION_NAMESPACE::hash_multimap<
|
|
Key, HashFcn, EqualKey, Allocator
|
|
> &t,
|
|
const unsigned int file_version
|
|
){
|
|
boost::serialization::stl::load_hash_collection<
|
|
Archive,
|
|
BOOST_STD_EXTENSION_NAMESPACE::hash_multimap<
|
|
Key, HashFcn, EqualKey, Allocator
|
|
>,
|
|
boost::serialization::stl::archive_input_hash_multimap<
|
|
Archive,
|
|
BOOST_STD_EXTENSION_NAMESPACE::hash_multimap<
|
|
Key, HashFcn, EqualKey, Allocator
|
|
>
|
|
>
|
|
>(ar, t);
|
|
}
|
|
|
|
// split non-intrusive serialization function member into separate
|
|
// non intrusive save/load member functions
|
|
template<
|
|
class Archive,
|
|
class Key,
|
|
class HashFcn,
|
|
class EqualKey,
|
|
class Allocator
|
|
>
|
|
inline void serialize(
|
|
Archive & ar,
|
|
BOOST_STD_EXTENSION_NAMESPACE::hash_multimap<
|
|
Key, HashFcn, EqualKey, Allocator
|
|
> &t,
|
|
const unsigned int file_version
|
|
){
|
|
boost::serialization::split_free(ar, t, file_version);
|
|
}
|
|
|
|
} // namespace serialization
|
|
} // namespace boost
|
|
|
|
#endif // BOOST_HAS_HASH
|
|
#endif // BOOST_SERIALIZATION_HASH_MAP_HPP
|