summaryrefslogtreecommitdiffstats
path: root/rdr/MemOutStream.h
diff options
context:
space:
mode:
authordscho <dscho>2002-10-22 08:47:29 +0000
committerdscho <dscho>2002-10-22 08:47:29 +0000
commit347ab48bd94a04b14009f0ac98df5b42d5da11a5 (patch)
tree89eb8ab0a1e4e0052e0c737bbe0a1174135b670b /rdr/MemOutStream.h
parentaf85e5fee34f7998fe3f06c799b8364a9ddbebce (diff)
downloadlibtdevnc-347ab48bd94a04b14009f0ac98df5b42d5da11a5.tar.gz
libtdevnc-347ab48bd94a04b14009f0ac98df5b42d5da11a5.zip
rdr
Diffstat (limited to 'rdr/MemOutStream.h')
-rw-r--r--rdr/MemOutStream.h82
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