X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/32fc4afbb253f55d4b35b7ee7a2ca9a7eea49fd9..9406d962ccf50d63f163896a2dd94123a2a8664a:/src/common/mstream.cpp diff --git a/src/common/mstream.cpp b/src/common/mstream.cpp index 3a1264e3fb..d75c423885 100644 --- a/src/common/mstream.cpp +++ b/src/common/mstream.cpp @@ -13,25 +13,67 @@ #pragma implementation "mstream.h" #endif +// For compilers that support precompilation, includes "wx.h". +#include "wx/wxprec.h" #include #include #include -wxMemoryStreamBase::wxMemoryStreamBase(char *data, size_t length, int iolimit) +#ifdef __BORLANDC__ +#pragma hdrstop +#endif + +// ---------------------------------------------------------------------------- +// 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; @@ -47,24 +89,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; @@ -74,7 +116,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; @@ -94,24 +155,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; @@ -121,13 +182,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() +{ }