/*************************************************************************** buffer.h - description ------------------- begin : Thu Jun 6 2002 Copyright (c) 2002 by Tom Linsky <twl6@po.cwru.edu> Copyright (c) 2003-2004 by Matt Rogers <mattr@kde.org> Kopete (c) 2002-2004 by the Kopete developers <kopete-devel@kde.org> ************************************************************************* * * * This program 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 * * (at your option) any later version. * * * ************************************************************************* */ #ifndef BUFFER_H #define BUFFER_H #include "oscartypes.h" #include <tqvaluelist.h> #include <tqcstring.h> class TQString; using namespace Oscar; /** * @brief A data buffer */ class Buffer { public: /** Default constructor */ Buffer(); Buffer( const Buffer& other ); /** * \brief Create a prefilled buffer * * Constructor that creates a prefilled buffer of @p len length * that contains the data from @p b. */ Buffer(const char *b, TQ_ULONG len); /** * \brief Create a prefilled buffer * * Constructor that creates a prefilled buffer from the TQByteArray \p data */ Buffer( const TQByteArray& data ); /** Default destructor */ ~Buffer(); /** * returns the raw buffer */ char *buffer() const; /** * Returns the remaining length of the buffer past the current read * position. */ int length() const; /** * adds the given string to the buffer (make sure it's NULL-terminated) */ int addString(TQByteArray); int addString(TQByteArray, DWORD); int addString(const char*, DWORD); int addString(const unsigned char*, DWORD); /** * Little-endian version of addString */ int addLEString(const char *, const DWORD); /** * adds the given string to the buffer with the length in front of it * (make sure it's NULL-terminated) */ int addLNTS(const char * s); /** * Little-endian version of addLNTS */ int addLELNTS(const char * s); /** * adds the given DWord to the buffer */ int addDWord(const DWORD); /** * adds the given word to the buffer */ int addWord(const WORD); /** * adds the given word to the buffer in * little-endian format as needed by old icq server */ int addLEWord(const WORD w); /** * adds the given DWord to the buffer in * little-endian format as needed by old icq server */ int addLEDWord(const DWORD dw); /** * adds the given byte to the buffer */ int addByte(const BYTE); int addLEByte(const BYTE); /** * empties the current buffer. */ void clear(); /** * Adds a TLV to the buffer */ int addTLV( const TLV& t ); /** * Adds a TLV with the given type and data */ int addTLV(WORD, WORD, const char *); /** * Adds a little-endian TLV with the given type and data */ int addLETLV(WORD, WORD, const char *); /** * Returns a TQString representation of the buffer */ TQString toString() const; /** * gets a DWord out of the buffer */ DWORD getDWord(); /** * Gets a word out of the buffer */ WORD getWord(); /** * Gets a byte out of the buffer * It's not a constant method. It advances the buffer * to the next BYTE after returning one. */ BYTE getByte(); /** * Skip \p bytesToSkip number of bytes in the buffer * Like getByte() the buffer is advanced when skipping */ void skipBytes( int bytesToSkip ); /** * Same as above but returns little-endian */ WORD getLEWord(); DWORD getLEDWord(); BYTE getLEByte(); /** * Set the buffer to the given values. */ void setBuf(char *, const WORD); /** * Allocates memory for and gets a block of buffer bytes */ TQByteArray getBlock(WORD len); TQByteArray getBBlock(WORD len); /** * Allocates memory for and gets a block of buffer words */ WORD *getWordBlock(WORD len); /** * Same as above but returning little-endian */ TQCString getLEBlock(WORD len); /** * Convenience function that gets a LNTS (long null terminated string) * from the buffer. Otherwise you'd need a getWord() + getBlock() call :) */ TQCString getLNTS(); TQCString getLELNTS(); /** * adds a 16-bit long TLV */ int addTLV16(const WORD type, const WORD data); /** * adds a 16-bit long little-endian TLV */ int addLETLV16(const WORD type, const WORD data); /** * adds the given byte to a TLV */ int addTLV8(const WORD type, const BYTE data); /** * adds the given byte to a little-endian TLV */ int addLETLV8(const WORD type, const BYTE data); /** * Gets a TLV, storing it in a struct and returning it */ TLV getTLV(); /** * Gets a list of TLV's */ TQValueList<TLV> getTLVList(); /** * Creates a chat data segment for a tlv and calls addTLV with that data */ int addChatTLV(const WORD, const WORD, const TQString &, const WORD); /** * Similar to the LNTS functions but string is NOT null-terminated */ int addBSTR(const char * s); TQByteArray getBSTR(); TQString peekBSTR(); int addBUIN(const char * s); TQByteArray getBUIN(); TQString peekBUIN(); operator TQByteArray() const; private: /** * Make the buffer bigger by @p inc bytes */ void expandBuffer(unsigned int inc); private: TQByteArray mBuffer; unsigned int mReadPos; }; #endif