X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/3cacae09fad9fee2c9cb222455e0f9aa4fa11d37..ba7f9a90b411a1b8b940d92c3fc26b2ee2cdafcc:/src/common/mstream.cpp diff --git a/src/common/mstream.cpp b/src/common/mstream.cpp index 7bed3cbf11..d19b9755df 100644 --- a/src/common/mstream.cpp +++ b/src/common/mstream.cpp @@ -13,32 +13,73 @@ #pragma implementation "mstream.h" #endif +// For compilers that support precompilation, includes "wx.h". +#include "wx/wxprec.h" #include #include #include +#ifdef __BORLANDC__ +#pragma hdrstop +#endif + #if !USE_SHARED_LIBRARY -IMPLEMENT_CLASS(wxMemoryStreamBase, wxStream) -IMPLEMENT_CLASS(wxMemoryInputStream, wxMemoryStreamBase) -IMPLEMENT_DYNAMIC_CLASS(wxMemoryOutputStream, wxMemoryStreamBase) -IMPLEMENT_DYNAMIC_CLASS(wxMemoryStream, wxMemoryStreamBase) +IMPLEMENT_CLASS(wxMemoryInputStream, wxInputStream) +IMPLEMENT_CLASS(wxMemoryOutputStream, wxOutputStream) +IMPLEMENT_CLASS2(wxMemoryStream, wxInputStream, wxOutputStream) #endif -wxMemoryStreamBase::wxMemoryStreamBase(char *data, size_t length, int iolimit) +// ---------------------------------------------------------------------------- +// wxMemoryStreamBase +// ---------------------------------------------------------------------------- +wxMemoryStreamBase::wxMemoryStreamBase() { - m_buffer = data; - m_iolimit = iolimit; + m_buffer = NULL; + m_iolimit = 0; m_persistent = FALSE; - m_length = length; - m_position_i = m_position_o = 0; + m_length = 0; } wxMemoryStreamBase::~wxMemoryStreamBase() { - free(m_buffer); + if (!m_persistent && m_buffer) + free(m_buffer); +} + +bool wxMemoryStreamBase::ChangeBufferSize(size_t new_size) +{ + if (m_iolimit == 1) + return FALSE; + + m_length = new_size; + if (!m_buffer) + m_buffer = (char *)malloc(m_length); + else + m_buffer = (char *)realloc(m_buffer, m_length); + + return (m_buffer != NULL); +} + +// ---------------------------------------------------------------------------- +// wxMemoryInputStream +// ---------------------------------------------------------------------------- + +wxMemoryInputStream::wxMemoryInputStream(const char *data, size_t len) +{ + m_persistent = TRUE; + m_length = len; + m_buffer = (char *)data; // It's bad. + m_position_i = 0; + m_lastread = 0; + m_eof = FALSE; + m_iolimit = 1; +} + +wxMemoryInputStream::~wxMemoryInputStream() +{ } -wxInputStream& wxMemoryStreamBase::Read(void *buffer, size_t size) +wxInputStream& wxMemoryInputStream::Read(void *buffer, size_t size) { if (m_iolimit == 2) { m_eof = TRUE; @@ -54,24 +95,24 @@ wxInputStream& wxMemoryStreamBase::Read(void *buffer, size_t size) return *this; } -size_t wxMemoryStreamBase::SeekI(int pos, wxWhenceType whence) +off_t wxMemoryInputStream::SeekI(off_t pos, wxSeekMode mode) { if (m_iolimit == 2) return 0; - switch (whence) { - case wxBeginPosition: + switch (mode) { + case wxFromStart: if ((size_t)pos > m_length) return m_position_i; return (m_position_i = pos); - case wxCurrentPosition: + case wxFromCurrent: if ((size_t)(m_position_i+pos) > m_length) return m_position_i; return (m_position_i += pos); - case wxEndPosition: + case wxFromEnd: if ((size_t)(m_length-pos) > m_length) return m_position_i; @@ -81,7 +122,26 @@ size_t wxMemoryStreamBase::SeekI(int pos, wxWhenceType whence) return m_position_i; } -wxOutputStream& wxMemoryStreamBase::Write(const void *buffer, size_t size) +// ---------------------------------------------------------------------------- +// wxMemoryOutputStream +// ---------------------------------------------------------------------------- + +wxMemoryOutputStream::wxMemoryOutputStream(char *data, size_t len) +{ + m_persistent = FALSE; + m_buffer = data; + m_length = len; + m_position_o = 0; + m_lastwrite = 0; + m_bad = FALSE; + m_iolimit = 2; +} + +wxMemoryOutputStream::~wxMemoryOutputStream() +{ +} + +wxOutputStream& wxMemoryOutputStream::Write(const void *buffer, size_t size) { if (m_iolimit == 1) { m_bad = TRUE; @@ -101,24 +161,24 @@ wxOutputStream& wxMemoryStreamBase::Write(const void *buffer, size_t size) return *this; } -size_t wxMemoryStreamBase::SeekO(int pos, wxWhenceType whence) +off_t wxMemoryOutputStream::SeekO(off_t pos, wxSeekMode mode) { - if (m_iolimit == 2) + if (m_iolimit == 1) return 0; - switch (whence) { - case wxBeginPosition: + switch (mode) { + case wxFromStart: if ((size_t)pos > m_length) return m_position_o; return (m_position_o = pos); - case wxCurrentPosition: + case wxFromCurrent: if ((size_t)(m_position_o+pos) > m_length) return m_position_o; return (m_position_o += pos); - case wxEndPosition: + case wxFromEnd: if ((size_t)(m_length-pos) > m_length) return m_position_o; @@ -128,13 +188,19 @@ size_t wxMemoryStreamBase::SeekO(int pos, wxWhenceType whence) return m_position_o; } -bool wxMemoryStreamBase::ChangeBufferSize(size_t new_size) +// ---------------------------------------------------------------------------- +// wxMemoryStream +// ---------------------------------------------------------------------------- + +wxMemoryStream::wxMemoryStream(char *data, size_t len) + : wxMemoryInputStream(NULL, 0), wxMemoryOutputStream(NULL, 0) { - m_length = new_size; - if (!m_buffer) - m_buffer = (char *)malloc(m_length); - else - m_buffer = (char *)realloc(m_buffer, m_length); + m_persistent = FALSE; + m_buffer = data; + m_length = len; + m_iolimit = 0; +} - return (m_buffer != NULL); +wxMemoryStream::~wxMemoryStream() +{ }