QxOrm
1.5.0
C++ Object Relational Mapping library
|
00001 /**************************************************************************** 00002 ** 00003 ** https://www.qxorm.com/ 00004 ** Copyright (C) 2013 Lionel Marty (contact@qxorm.com) 00005 ** 00006 ** This file is part of the QxOrm library 00007 ** 00008 ** This software is provided 'as-is', without any express or implied 00009 ** warranty. In no event will the authors be held liable for any 00010 ** damages arising from the use of this software 00011 ** 00012 ** Commercial Usage 00013 ** Licensees holding valid commercial QxOrm licenses may use this file in 00014 ** accordance with the commercial license agreement provided with the 00015 ** Software or, alternatively, in accordance with the terms contained in 00016 ** a written agreement between you and Lionel Marty 00017 ** 00018 ** GNU General Public License Usage 00019 ** Alternatively, this file may be used under the terms of the GNU 00020 ** General Public License version 3.0 as published by the Free Software 00021 ** Foundation and appearing in the file 'license.gpl3.txt' included in the 00022 ** packaging of this file. Please review the following information to 00023 ** ensure the GNU General Public License version 3.0 requirements will be 00024 ** met : http://www.gnu.org/copyleft/gpl.html 00025 ** 00026 ** If you are unsure which license is appropriate for your use, or 00027 ** if you have questions regarding the use of this file, please contact : 00028 ** contact@qxorm.com 00029 ** 00030 ****************************************************************************/ 00031 00032 #ifdef _QX_ENABLE_BOOST_SERIALIZATION 00033 #ifndef _QX_SERIALIZATION_BOOST_UNORDERED_MAP_H_ 00034 #define _QX_SERIALIZATION_BOOST_UNORDERED_MAP_H_ 00035 00036 #ifdef _MSC_VER 00037 #pragma once 00038 #endif 00039 00040 #include <boost/serialization/serialization.hpp> 00041 #include <boost/serialization/collections_save_imp.hpp> 00042 #include <boost/serialization/collections_load_imp.hpp> 00043 #include <boost/serialization/split_free.hpp> 00044 #include <boost/serialization/utility.hpp> 00045 #include <boost/serialization/nvp.hpp> 00046 00047 namespace boost { 00048 namespace serialization { 00049 00050 #if (BOOST_VERSION > 105700) 00051 00052 template <class Archive, class Key, class Value> 00053 inline void save(Archive & ar, const boost::unordered_map<Key, Value> & t, const unsigned int /* file_version */) 00054 { 00055 long lSize = static_cast<long>(t.size()); 00056 ar << boost::serialization::make_nvp("size", lSize); 00057 00058 typedef typename boost::unordered_map<Key, Value>::const_iterator type_itr; 00059 for (type_itr itr = t.begin(); itr != t.end(); ++itr) 00060 { 00061 std::pair<Key, Value> pair_key_value = std::make_pair(itr->first, itr->second); 00062 ar << boost::serialization::make_nvp("item", pair_key_value); 00063 } 00064 } 00065 00066 template <class Archive, class Key, class Value> 00067 inline void load(Archive & ar, boost::unordered_map<Key, Value> & t, const unsigned int /* file_version */) 00068 { 00069 long lSize = 0; 00070 ar >> boost::serialization::make_nvp("size", lSize); 00071 00072 t.clear(); 00073 t.reserve(lSize); 00074 std::pair<Key, Value> pair_key_value; 00075 00076 for (long l = 0; l < lSize; l++) 00077 { 00078 ar >> boost::serialization::make_nvp("item", pair_key_value); 00079 t.insert(pair_key_value); 00080 } 00081 } 00082 00083 #else // (BOOST_VERSION > 105700) 00084 00085 template <class Archive, class Key, class Value> 00086 inline void save(Archive & ar, const boost::unordered_map<Key, Value> & t, const unsigned int /* file_version */) 00087 { 00088 boost::serialization::stl::save_collection< Archive, boost::unordered_map<Key, Value> >(ar, t); 00089 } 00090 00091 template <class Archive, class Key, class Value> 00092 inline void load(Archive & ar, boost::unordered_map<Key, Value> & t, const unsigned int /* file_version */) 00093 { 00094 boost::serialization::stl::load_collection< Archive, boost::unordered_map<Key, Value>, 00095 boost::serialization::stl::archive_input_map< Archive, boost::unordered_map<Key, Value> >, 00096 boost::serialization::stl::no_reserve_imp< boost::unordered_map<Key, Value> > >(ar, t); 00097 } 00098 00099 #endif // (BOOST_VERSION > 105700) 00100 00101 template <class Archive, class Key, class Value> 00102 inline void serialize(Archive & ar, boost::unordered_map<Key, Value> & t, const unsigned int file_version) 00103 { 00104 boost::serialization::split_free(ar, t, file_version); 00105 } 00106 00107 #if (BOOST_VERSION > 105700) 00108 00109 template <class Archive, class Key, class Value> 00110 inline void save(Archive & ar, const boost::unordered_multimap<Key, Value> & t, const unsigned int /* file_version */) 00111 { 00112 long lSize = static_cast<long>(t.size()); 00113 ar << boost::serialization::make_nvp("size", lSize); 00114 00115 typedef typename boost::unordered_multimap<Key, Value>::const_iterator type_itr; 00116 for (type_itr itr = t.begin(); itr != t.end(); ++itr) 00117 { 00118 std::pair<Key, Value> pair_key_value = std::make_pair(itr->first, itr->second); 00119 ar << boost::serialization::make_nvp("item", pair_key_value); 00120 } 00121 } 00122 00123 template <class Archive, class Key, class Value> 00124 inline void load(Archive & ar, boost::unordered_multimap<Key, Value> & t, const unsigned int /* file_version */) 00125 { 00126 long lSize = 0; 00127 ar >> boost::serialization::make_nvp("size", lSize); 00128 00129 t.clear(); 00130 t.reserve(lSize); 00131 std::pair<Key, Value> pair_key_value; 00132 00133 for (long l = 0; l < lSize; l++) 00134 { 00135 ar >> boost::serialization::make_nvp("item", pair_key_value); 00136 t.insert(pair_key_value); 00137 } 00138 } 00139 00140 #else // (BOOST_VERSION > 105700) 00141 00142 template <class Archive, class Key, class Value> 00143 inline void save(Archive & ar, const boost::unordered_multimap<Key, Value> & t, const unsigned int /* file_version */) 00144 { 00145 boost::serialization::stl::save_collection< Archive, boost::unordered_multimap<Key, Value> >(ar, t); 00146 } 00147 00148 template <class Archive, class Key, class Value> 00149 inline void load(Archive & ar, boost::unordered_multimap<Key, Value> & t, const unsigned int /* file_version */) 00150 { 00151 #if (BOOST_VERSION >= 104200) 00152 boost::serialization::stl::load_collection< Archive, boost::unordered_multimap<Key, Value>, 00153 boost::serialization::stl::archive_input_map< Archive, boost::unordered_multimap<Key, Value> >, 00154 boost::serialization::stl::no_reserve_imp< boost::unordered_multimap<Key, Value> > >(ar, t); 00155 #else // (BOOST_VERSION >= 104200) 00156 boost::serialization::stl::load_collection< Archive, boost::unordered_multimap<Key, Value>, 00157 boost::serialization::stl::archive_input_multimap< Archive, boost::unordered_multimap<Key, Value> >, 00158 boost::serialization::stl::no_reserve_imp< boost::unordered_multimap<Key, Value> > >(ar, t); 00159 #endif // (BOOST_VERSION >= 104200) 00160 } 00161 00162 #endif // (BOOST_VERSION > 105700) 00163 00164 template <class Archive, class Key, class Value> 00165 inline void serialize(Archive & ar, boost::unordered_multimap<Key, Value> & t, const unsigned int file_version) 00166 { 00167 boost::serialization::split_free(ar, t, file_version); 00168 } 00169 00170 } // namespace serialization 00171 } // namespace boost 00172 00173 #endif // _QX_SERIALIZATION_BOOST_UNORDERED_MAP_H_ 00174 #endif // _QX_ENABLE_BOOST_SERIALIZATION