12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 |
- #ifndef BOOST_SERIALIZATION_HASH_COLLECTIONS_SAVE_IMP_HPP
- #define BOOST_SERIALIZATION_HASH_COLLECTIONS_SAVE_IMP_HPP
- #if defined(_MSC_VER)
- # pragma once
- #endif
- #include <boost/config.hpp>
- #include <boost/serialization/nvp.hpp>
- #include <boost/serialization/serialization.hpp>
- #include <boost/serialization/collection_size_type.hpp>
- #include <boost/serialization/item_version_type.hpp>
- #include <boost/serialization/library_version_type.hpp>
- namespace boost{
- namespace serialization {
- namespace stl {
- template<class Archive, class Container>
- inline void save_hash_collection(Archive & ar, const Container &s)
- {
- collection_size_type count(s.size());
- const collection_size_type bucket_count(s.bucket_count());
- const item_version_type item_version(
- version<typename Container::value_type>::value
- );
- #if 0
-
- boost::serialization::library_version_type library_version(
- ar.get_library_version()
- );
-
- if(boost::serialization::library_version_type(6) != library_version){
- ar << BOOST_SERIALIZATION_NVP(count);
- ar << BOOST_SERIALIZATION_NVP(bucket_count);
- }
- else{
-
-
-
-
- const unsigned int c = count;
- const unsigned int bc = bucket_count;
- ar << BOOST_SERIALIZATION_NVP(c);
- ar << BOOST_SERIALIZATION_NVP(bc);
- }
- if(boost::serialization::library_version_type(3) < library_version){
-
-
-
- ar << BOOST_SERIALIZATION_NVP(item_version);
- }
- #else
- ar << BOOST_SERIALIZATION_NVP(count);
- ar << BOOST_SERIALIZATION_NVP(bucket_count);
- ar << BOOST_SERIALIZATION_NVP(item_version);
- #endif
- typename Container::const_iterator it = s.begin();
- while(count-- > 0){
-
- boost::serialization::save_construct_data_adl(
- ar,
- &(*it),
- boost::serialization::version<
- typename Container::value_type
- >::value
- );
- ar << boost::serialization::make_nvp("item", *it++);
- }
- }
- }
- }
- }
- #endif
|