// // Copyright (c) 2011 Alex Yatskov // // Permission is hereby granted, free of charge, to any person // obtaining a copy of this software and associated documentation // files (the "Software"), to deal in the Software without // restriction, including without limitation the rights to use, // copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the // Software is furnished to do so, subject to the following // conditions: // // The above copyright notice and this permission notice shall be // included in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES // OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT // HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, // WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR // OTHER DEALINGS IN THE SOFTWARE. // namespace metacall { // // std::basic_string // template void serialize(Serializer* serializer, const std::basic_string& value) { serialize(serializer, value.c_str()); } template bool deserialize(Deserializer* deserializer, std::basic_string* value) { value->clear(); const T * str = NULL; if (!deserialize(deserializer, &str)) { return false; } if (str != NULL) { *value = str; } return true; } // // std::vector // template void serialize(Serializer* serializer, const std::vector& value) { serializer->write(value.size()); for (const typename std::vector::const_iterator iter = value.begin(); iter != value.end(); ++iter) { serializer->write(*iter); } } template bool deserialize(Deserializer* deserializer, std::vector* value) { value->clear(); int length = 0; if (!deserializer->read(&length)) { return false; } for (int i = 0; i < length; ++i) { T item = T(); if (!deserializer->read(&item)) { return false; } value->push_back(item); } return true; } // // std::list // template void serialize(Serializer* serializer, const std::list& value) { serializer->write(value.size()); for (const typename std::list::const_iterator iter = value.begin(); iter != value.end(); ++iter) { serializer->write(*iter); } } template bool deserialize(Deserializer* deserializer, std::list* value) { value->clear(); int length = 0; if (!deserializer->read(&length)) { return false; } for (int i = 0; i < length; ++i) { T item = T(); if (!deserializer->read(&item)) { return false; } value->push_back(item); } return true; } // // std::pair // template void serialize(Serializer* serializer, const std::pair& value) { serializer->write(value.first); serializer->write(value.second); return true; } template bool deserialize(Deserializer* deserializer, std::pair* value) { return deserializer->read(&value->first) && deserializer->read(&value->second); } // // std::map // template void serialize(Serializer* serializer, const std::map& value) { serializer->write(value.size()); for (const typename std::map::const_iterator iter = value.begin(); iter != value.end(); ++iter) { serializer->write(*iter); } } template bool deserialize(Deserializer* deserializer, std::map* value) { value->clear(); int length = 0; if (!deserializer->read(&length)) { return false; } for (unsigned i = 0; i < length; ++i) { std::pair item; if (!deserializer->read(&item)) { return false; } value->insert(item); } return true; } }