/* * The Mana World * Copyright 2004 The Mana World Development Team * * This file is part of The Mana World. * * The Mana World is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * any later version. * * The Mana World 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with The Mana World; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * * $Id$ */ #include "messageout.h" #include #include #include #include "network.h" #include "packet.h" MessageOut::MessageOut(): mPacket(0), mData(0), mDataSize(0), mPos(0) { mData = out + out_size; } MessageOut::~MessageOut() { if (mPacket) { delete mPacket; } // Don't free this data for now, see above. //if (mData) { // free(mData); //} } void MessageOut::expand(size_t bytes) { /*mData = (char*)realloc(mData, bytes); mDataSize = bytes;*/ } void MessageOut::writeByte(char value) { expand(mPos + sizeof(char)); mData[mPos] = value; mPos += sizeof(char); out_size += sizeof(char); } void MessageOut::writeShort(short value) { expand(mPos + sizeof(short)); #if SDL_BYTEORDER == SDL_BIG_ENDIAN (*(short *)(mData + mPos)) = SDL_Swap16(value); #else (*(short *)(mData + mPos)) = value; #endif mPos += sizeof(short); out_size += sizeof(short); } /* writeLong should use an int because long is 8 bytes in x86_64 arch ! */ void MessageOut::writeLong(int value) { expand(mPos + sizeof(int)); #if SDL_BYTEORDER == SDL_BIG_ENDIAN (*(int *)(mData + mPos)) = SDL_Swap32(value); #else (*(int *)(mData + mPos)) = value; #endif mPos += sizeof(int); out_size += sizeof(int); } void MessageOut::writeString(const std::string &string, int length) { std::string toWrite = string; if (length < 0) { // Write the length at the start if not fixed writeShort(string.length()); expand(mPos + string.length()); } else { // Make sure the length of the string is no longer than specified toWrite = string.substr(0, length); expand(mPos + length); } // Write the actual string memcpy(&mData[mPos], (void*)toWrite.c_str(), toWrite.length()); mPos += toWrite.length(); out_size += toWrite.length(); // Pad remaining space with zeros if (length > (int)toWrite.length()) { memset(&mData[mPos], '\0', length - toWrite.length()); mPos += length - toWrite.length(); out_size += length - toWrite.length(); } } const Packet *MessageOut::getPacket() { if (!mPacket) { mPacket = new Packet(mData, mDataSize); } return mPacket; } MessageOut& operator<<(MessageOut &msg, const char &rhs) { msg.writeByte(rhs); return msg; } MessageOut& operator<<(MessageOut &msg, const short &rhs) { msg.writeShort(rhs); return msg; } MessageOut& operator<<(MessageOut &msg, const long &rhs) { msg.writeLong(rhs); return msg; }