]> git.saurik.com Git - wxWidgets.git/blame - src/common/mstream.cpp
help search is much faster now (7 times! that's what I call optimization ;-)
[wxWidgets.git] / src / common / mstream.cpp
CommitLineData
3d4c6a21 1/////////////////////////////////////////////////////////////////////////////
32fc4afb 2// Name: mstream.cpp
3d4c6a21
GL
3// Purpose: "Memory stream" classes
4// Author: Guilhem Lavaux
5// Modified by:
6// Created: 04/01/98
7// RCS-ID: $Id$
8// Copyright: (c) Guilhem Lavaux
9// Licence: wxWindows license
10/////////////////////////////////////////////////////////////////////////////
11
12#ifdef __GNUG__
32fc4afb 13#pragma implementation "mstream.h"
3d4c6a21
GL
14#endif
15
79c3e0e1
GL
16// For compilers that support precompilation, includes "wx.h".
17#include "wx/wxprec.h"
79c3e0e1
GL
18
19#ifdef __BORLANDC__
ce4169a4 20 #pragma hdrstop
79c3e0e1 21#endif
3d4c6a21 22
ce4169a4
RR
23#if wxUSE_STREAMS
24
25#include <stdlib.h>
3096bd2f
VZ
26#include "wx/stream.h"
27#include "wx/mstream.h"
ce4169a4 28
79c3e0e1
GL
29// ----------------------------------------------------------------------------
30// wxMemoryInputStream
31// ----------------------------------------------------------------------------
32
33wxMemoryInputStream::wxMemoryInputStream(const char *data, size_t len)
75ed1d15 34 : wxInputStream()
79c3e0e1 35{
c980c992 36 m_i_streambuf = new wxStreamBuffer(wxStreamBuffer::read);
2d0a075d 37 m_i_streambuf->SetBufferIO((char*) data, (char*) (data+len));
18c07b73 38 m_i_streambuf->SetIntPosition(0); // seek to start pos
75ed1d15 39 m_i_streambuf->Fixed(TRUE);
c980c992 40
18c07b73 41 m_length = len;
3d4c6a21
GL
42}
43
0cd9bfe8
GL
44wxMemoryInputStream::~wxMemoryInputStream()
45{
c980c992 46 delete m_i_streambuf;
0cd9bfe8
GL
47}
48
32a4b1d5
GL
49char wxMemoryInputStream::Peek()
50{
75ed1d15 51 return m_i_streambuf->GetBufferStart()[m_i_streambuf->GetIntPosition()];
c980c992
GL
52}
53
54size_t wxMemoryInputStream::OnSysRead(void *buffer, size_t nbytes)
55{
bc83ea24 56 m_lastcount = 0;
c980c992
GL
57 return m_i_streambuf->Read(buffer, nbytes);
58}
59
60off_t wxMemoryInputStream::OnSysSeek(off_t pos, wxSeekMode mode)
61{
62 return m_i_streambuf->Seek(pos, mode);
63}
64
65off_t wxMemoryInputStream::OnSysTell() const
66{
67 return m_i_streambuf->Tell();
3d4c6a21
GL
68}
69
79c3e0e1
GL
70// ----------------------------------------------------------------------------
71// wxMemoryOutputStream
72// ----------------------------------------------------------------------------
73
74wxMemoryOutputStream::wxMemoryOutputStream(char *data, size_t len)
75ed1d15 75 : wxOutputStream()
79c3e0e1 76{
c980c992 77 m_o_streambuf = new wxStreamBuffer(wxStreamBuffer::write);
75ed1d15
GL
78 if (data)
79 m_o_streambuf->SetBufferIO(data, data+len);
56dc1ffd
GL
80 m_o_streambuf->Fixed(FALSE);
81 m_o_streambuf->Flushable(FALSE);
79c3e0e1
GL
82}
83
0cd9bfe8 84wxMemoryOutputStream::~wxMemoryOutputStream()
79c3e0e1 85{
c980c992 86 delete m_o_streambuf;
3d4c6a21 87}
ce4169a4 88
c980c992
GL
89size_t wxMemoryOutputStream::OnSysWrite(const void *buffer, size_t nbytes)
90{
bc83ea24 91 m_lastcount = 0;
c980c992
GL
92 return m_o_streambuf->Write(buffer, nbytes);
93}
94
95off_t wxMemoryOutputStream::OnSysSeek(off_t pos, wxSeekMode mode)
96{
97 return m_o_streambuf->Seek(pos, mode);
98}
99
100off_t wxMemoryOutputStream::OnSysTell() const
101{
102 return m_o_streambuf->Tell();
103}
104
a324a7bc
GL
105size_t wxMemoryOutputStream::CopyTo(char *buffer, size_t len) const
106{
107 if (!buffer)
108 return 0;
109
cd25b18c
RR
110 if (len > GetSize())
111 len = GetSize();
a324a7bc
GL
112
113 memcpy(buffer, m_o_streambuf->GetBufferStart(), len);
114 return len;
115}
c980c992 116
ce4169a4 117#endif