X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/6d5a34485ba36dac14bc4bf7ab788dcad2b22b9a..3f3af7e7f8625baf8e72951c066fecf61ea46821:/src/common/sstream.cpp?ds=sidebyside diff --git a/src/common/sstream.cpp b/src/common/sstream.cpp index cd9a0a1cdc..8033dff28c 100644 --- a/src/common/sstream.cpp +++ b/src/common/sstream.cpp @@ -36,7 +36,9 @@ // construction/destruction // ---------------------------------------------------------------------------- -wxStringInputStream::wxStringInputStream(const wxString& s) +// TODO: Do we want to include the null char in the stream? If so then +// just add +1 to m_len in the ctor +wxStringInputStream::wxStringInputStream(const wxString& s) #if wxUSE_UNICODE : m_str(s), m_buf(wxMBConvUTF8().cWX2MB(s).release()), m_len(strlen(m_buf)) #else @@ -52,7 +54,8 @@ wxStringInputStream::wxStringInputStream(const wxString& s) wxStringInputStream::~wxStringInputStream() { #if wxUSE_UNICODE - delete[] m_buf; + // Note: wx[W]CharBuffer uses malloc()/free() + free(m_buf); #endif } @@ -90,10 +93,11 @@ wxFileOffset wxStringInputStream::OnSysSeek(wxFileOffset ofs, wxSeekMode mode) return wxInvalidOffset; } - if ( ofs < 0 || wx_static_cast(size_t, ofs) >= m_len ) + if ( ofs < 0 || ofs > wx_static_cast(wxFileOffset, m_len) ) return wxInvalidOffset; - m_pos = wx_static_cast(size_t, ofs); + // FIXME: this can't be right + m_pos = wx_truncate_cast(size_t, ofs); return ofs; } @@ -153,9 +157,10 @@ size_t wxStringOutputStream::OnSysWrite(const void *buffer, size_t size) // the literal length m_str->Append(wxString(p, m_conv, size)); - // return number of bytes actually written + // update position m_pos += size; + // return number of bytes actually written return size; }