#ifndef BOOST_SERIALIZATION_VECTOR_HPP #define BOOST_SERIALIZATION_VECTOR_HPP // MS compatible compilers support #pragma once #if defined(_MSC_VER) # pragma once #endif /////////1/////////2/////////3/////////4/////////5/////////6/////////7/////////8 // vector.hpp: serialization for stl vector templates // (C) Copyright 2002 Robert Ramey - http://www.rrsd.com . // fast array serialization (C) Copyright 2005 Matthias Troyer // 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 #include #include // default is being compatible with version 1.34.1 files, not 1.35 files #ifndef BOOST_SERIALIZATION_VECTOR_VERSIONED #define BOOST_SERIALIZATION_VECTOR_VERSIONED(V) (V==4 || V==5) #endif // function specializations must be defined in the appropriate // namespace - boost::serialization #if defined(__SGI_STL_PORT) || defined(_STLPORT_VERSION) #define STD _STLP_STD #else #define STD std #endif namespace boost { namespace serialization { /////////1/////////2/////////3/////////4/////////5/////////6/////////7/////////8 // vector< T > // the default versions template inline void save( Archive & ar, const std::vector &t, const unsigned int /* file_version */, mpl::false_ ){ boost::serialization::stl::save_collection >( ar, t ); } template inline void load( Archive & ar, std::vector &t, const unsigned int /* file_version */, mpl::false_ ){ const boost::archive::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::archive::library_version_type(3) < library_version){ ar >> BOOST_SERIALIZATION_NVP(item_version); } t.reserve(count); stl::collection_load_impl(ar, t, count, item_version); } // the optimized versions template inline void save( Archive & ar, const std::vector &t, const unsigned int /* file_version */, mpl::true_ ){ const collection_size_type count(t.size()); ar << BOOST_SERIALIZATION_NVP(count); if (!t.empty()) // explict template arguments to pass intel C++ compiler ar << serialization::make_array( static_cast(&t[0]), count ); } template inline void load( Archive & ar, std::vector &t, const unsigned int /* file_version */, mpl::true_ ){ collection_size_type count(t.size()); ar >> BOOST_SERIALIZATION_NVP(count); t.resize(count); unsigned int item_version=0; if(BOOST_SERIALIZATION_VECTOR_VERSIONED(ar.get_library_version())) { ar >> BOOST_SERIALIZATION_NVP(item_version); } if (!t.empty()) // explict template arguments to pass intel C++ compiler ar >> serialization::make_array( static_cast(&t[0]), count ); } // dispatch to either default or optimized versions template inline void save( Archive & ar, const std::vector &t, const unsigned int file_version ){ typedef typename boost::serialization::use_array_optimization::template apply< typename remove_const::type >::type use_optimized; save(ar,t,file_version, use_optimized()); } template inline void load( Archive & ar, std::vector &t, const unsigned int file_version ){ #ifdef BOOST_SERIALIZATION_VECTOR_135_HPP if (ar.get_library_version()==boost::archive::library_version_type(5)) { load(ar,t,file_version, boost::is_arithmetic()); return; } #endif typedef typename boost::serialization::use_array_optimization::template apply< typename remove_const::type >::type use_optimized; load(ar,t,file_version, use_optimized()); } // split non-intrusive serialization function member into separate // non intrusive save/load member functions template inline void serialize( Archive & ar, std::vector & t, const unsigned int file_version ){ boost::serialization::split_free(ar, t, file_version); } /////////1/////////2/////////3/////////4/////////5/////////6/////////7/////////8 // vector template inline void save( Archive & ar, const std::vector &t, const unsigned int /* file_version */ ){ // record number of elements collection_size_type count (t.size()); ar << BOOST_SERIALIZATION_NVP(count); std::vector::const_iterator it = t.begin(); while(count-- > 0){ bool tb = *it++; ar << boost::serialization::make_nvp("item", tb); } } template inline void load( Archive & ar, std::vector &t, const unsigned int /* file_version */ ){ // retrieve number of elements collection_size_type count; ar >> BOOST_SERIALIZATION_NVP(count); t.resize(count); for(collection_size_type i = collection_size_type(0); i < count; ++i){ bool b; ar >> boost::serialization::make_nvp("item", b); t[i] = b; } } // split non-intrusive serialization function member into separate // non intrusive save/load member functions template inline void serialize( Archive & ar, std::vector & t, const unsigned int file_version ){ boost::serialization::split_free(ar, t, file_version); } } // serialization } // namespace boost #include BOOST_SERIALIZATION_COLLECTION_TRAITS(std::vector) #undef STD #endif // BOOST_SERIALIZATION_VECTOR_HPP