#ifndef BOOST_SERIALIZATION_PTR_COLLECTIONS_LOAD_IMP_HPP #define BOOST_SERIALIZATION_PTR_COLLECTIONS_LOAD_IMP_HPP // MS compatible compilers support #pragma once #if defined(_MSC_VER) && (_MSC_VER >= 1020) # pragma once #endif #if defined(_MSC_VER) && (_MSC_VER <= 1020) # pragma warning (disable : 4786) // too long name, harmless warning #endif /////////1/////////2/////////3/////////4/////////5/////////6/////////7/////////8 // collections_load_imp.hpp: serialization for loading stl collections // (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. // helper function templates for serialization of collections #include #include #include #include #include #include #include #include #include namespace boost{ namespace serialization { namespace stl { // sequential container input template struct archive_input_ptr_seq { inline void operator()(Archive &ar, Container &s) { typedef BOOST_DEDUCED_TYPENAME Container::pointer pointer; pointer t; // borland fails silently w/o full namespace ar >> boost::serialization::make_nvp("item", t); s.push_back(t); ar.reset_object_address(& s.back() , & t); } }; /* // map input template struct archive_input_map { inline void operator()(Archive &ar, Container &s) { #if BOOST_WORKAROUND(BOOST_DINKUMWARE_STDLIB, == 1) typedef BOOST_DEDUCED_TYPENAME std::pair< BOOST_DEDUCED_TYPENAME Container::key_type, BOOST_DEDUCED_TYPENAME Container::referent_type > type; #else typedef BOOST_DEDUCED_TYPENAME std::pair< BOOST_DEDUCED_TYPENAME Container::key_type, BOOST_DEDUCED_TYPENAME Container::mapped_type > type; #endif stack_construct t(ar); // borland fails silently w/o full namespace ar >> boost::serialization::make_nvp("item", t.reference()); std::pair result = s.insert(t.reference()); assert(result.second); // make sure we inserted a new element ar.reset_object_address(& (* result.first), & t); } }; // set input template struct archive_input_set { inline void operator()(Archive &ar, Container &s) { typedef BOOST_DEDUCED_TYPENAME Container::value_type type; stack_construct t(ar); // borland fails silently w/o full namespace ar >> boost::serialization::make_nvp("item", t.reference()); std::pair result = s.insert(t.reference()); assert(result.second); // make sure we inserted a new element ar.reset_object_address(& (* result.first), & t); } }; // multimap input template struct archive_input_multimap { inline void operator()(Archive &ar, Container &s) { #if BOOST_WORKAROUND(BOOST_DINKUMWARE_STDLIB, == 1) typedef BOOST_DEDUCED_TYPENAME std::pair< BOOST_DEDUCED_TYPENAME Container::key_type, BOOST_DEDUCED_TYPENAME Container::referent_type > type; #else typedef BOOST_DEDUCED_TYPENAME std::pair< BOOST_DEDUCED_TYPENAME Container::key_type, BOOST_DEDUCED_TYPENAME Container::mapped_type > type; #endif stack_construct t(ar); // borland fails silently w/o full namespace ar >> boost::serialization::make_nvp("item", t.reference()); BOOST_DEDUCED_TYPENAME Container::const_iterator result = s.insert(t.reference()); ar.reset_object_address(& (* result), & t); } }; // multiset input template struct archive_input_multiset { inline void operator()(Archive &ar, Container &s) { typedef BOOST_DEDUCED_TYPENAME Container::value_type type; stack_construct t(ar); // borland fails silently w/o full namespace ar >> boost::serialization::make_nvp("item", t.reference()); BOOST_DEDUCED_TYPENAME Container::const_iterator result = s.insert(t.reference()); ar.reset_object_address(& (* result), & t); } }; */ template inline void rebuild_ptr_collection(Archive & ar, Container &s) { s.clear(); // retrieve number of elements unsigned int count; ar >> BOOST_SERIALIZATION_NVP(count); R rx; rx(s, count); InputFunction ifunc; while(count-- > 0){ ifunc(ar, s); } } /* template inline void copy_ptr_collection(Archive & ar, Container &s) { // retrieve number of elements unsigned int count; ar >> BOOST_SERIALIZATION_NVP(count); assert(count == s.size()); BOOST_DEDUCED_TYPENAME Container::iterator it = s.begin(); while(count-- > 0){ ar >> boost::serialization::make_nvp("item", *it++); } } */ template inline void load_ptr_collection(Archive & ar, Container &s){ // if(0 != (ar.get_flags() & boost::archive::no_object_creation)) // copy_collection(ar, s); // else rebuild_ptr_collection(ar, s); } } // namespace stl } // namespace serialization } // namespace boost #endif //BOOST_SERIALIZATION_PTR_COLLECTIONS_LOAD_IMP_HPP