/* Minetest Copyright (C) 2010-2013 celeron55, Perttu Ahola This program is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ #include "serialize.h" #include "pointer.h" #include "../exceptions.h" #include #include // Creates a string with the length as the first two bytes std::string serializeString(const std::string &plain) { //assert(plain.size() <= 65535); if(plain.size() > 65535) throw SerializationError("String too long for serializeString"); char buf[2]; writeU16((u8*)&buf[0], plain.size()); std::string s; s.append(buf, 2); s.append(plain); return s; } // Creates a string with the length as the first two bytes from wide string std::string serializeWideString(const std::wstring &plain) { //assert(plain.size() <= 65535); if(plain.size() > 65535) throw SerializationError("String too long for serializeString"); char buf[2]; writeU16((u8*)buf, plain.size()); std::string s; s.append(buf, 2); for(u32 i=0; i buf2(s_size); is.read(&buf2[0], s_size); std::string s; s.reserve(s_size); s.append(&buf2[0], s_size); return s; } // Reads a wide string with the length as the first two bytes std::wstring deSerializeWideString(std::istream &is) { char buf[2]; is.read(buf, 2); if(is.gcount() != 2) throw SerializationError("deSerializeString: size not read"); u16 s_size = readU16((u8*)buf); if(s_size == 0) return L""; std::wstring s; s.reserve(s_size); for(u32 i=0; i buf2(s_size); is.read(&buf2[0], s_size); std::string s; s.reserve(s_size); s.append(&buf2[0], s_size); return s; } // Creates a string encoded in JSON format (almost equivalent to a C string literal) std::string serializeJsonString(const std::string &plain) { std::ostringstream os(std::ios::binary); os<<"\""; for(size_t i = 0; i < plain.size(); i++) { char c = plain[i]; switch(c) { case '"': os<<"\\\""; break; case '\\': os<<"\\\\"; break; case '/': os<<"\\/"; break; case '\b': os<<"\\b"; break; case '\f': os<<"\\f"; break; case '\n': os<<"\\n"; break; case '\r': os<<"\\r"; break; case '\t': os<<"\\t"; break; default: { if(c >= 32 && c <= 126) { os<> c; if(c != '"') throw SerializationError("JSON string must start with doublequote"); // Parse characters for(;;) { c = is.get(); if(is.eof()) throw SerializationError("JSON string ended prematurely"); if(c == '"') { return os.str(); } else if(c == '\\') { c2 = is.get(); if(is.eof()) throw SerializationError("JSON string ended prematurely"); switch(c2) { default: os<> std::hex >> hexnumber; os<<((char)hexnumber); break; } } } else { os<