diff options
author | dscho <dscho> | 2002-10-22 08:47:29 +0000 |
---|---|---|
committer | dscho <dscho> | 2002-10-22 08:47:29 +0000 |
commit | 347ab48bd94a04b14009f0ac98df5b42d5da11a5 (patch) | |
tree | 89eb8ab0a1e4e0052e0c737bbe0a1174135b670b /rdr/MemOutStream.h | |
parent | af85e5fee34f7998fe3f06c799b8364a9ddbebce (diff) | |
download | libtdevnc-347ab48bd94a04b14009f0ac98df5b42d5da11a5.tar.gz libtdevnc-347ab48bd94a04b14009f0ac98df5b42d5da11a5.zip |
rdr
Diffstat (limited to 'rdr/MemOutStream.h')
-rw-r--r-- | rdr/MemOutStream.h | 82 |
1 files changed, 82 insertions, 0 deletions
diff --git a/rdr/MemOutStream.h b/rdr/MemOutStream.h new file mode 100644 index 0000000..0031388 --- /dev/null +++ b/rdr/MemOutStream.h @@ -0,0 +1,82 @@ +// +// Copyright (C) 2002 RealVNC Ltd. All Rights Reserved. +// +// This 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. +// +// This software 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 this software; if not, write to the Free Software +// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, +// USA. + +// +// A MemOutStream grows as needed when data is written to it. +// + +#ifndef __RDR_MEMOUTSTREAM_H__ +#define __RDR_MEMOUTSTREAM_H__ + +#include <rdr/OutStream.h> + +namespace rdr { + + class MemOutStream : public OutStream { + + public: + + MemOutStream(int len=1024) { + start = ptr = new U8[len]; + end = start + len; + } + + virtual ~MemOutStream() { + delete [] start; + } + + void writeBytes(const void* data, int length) { + check(length); + memcpy(ptr, data, length); + ptr += length; + } + + int length() { return ptr - start; } + void clear() { ptr = start; }; + void reposition(int pos) { ptr = start + pos; } + + // data() returns a pointer to the buffer. + + const void* data() { return (const void*)start; } + + private: + + // overrun() either doubles the buffer or adds enough space for nItems of + // size itemSize bytes. + + int overrun(int itemSize, int nItems) { + int len = ptr - start + itemSize * nItems; + if (len < (end - start) * 2) + len = (end - start) * 2; + + U8* newStart = new U8[len]; + memcpy(newStart, start, ptr - start); + ptr = newStart + (ptr - start); + delete [] start; + start = newStart; + end = newStart + len; + + return nItems; + } + + U8* start; + }; + +} + +#endif |