X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/60431236a330a9f3f1d071719e818812820b4d0c..0aaa804e7019b8187e2d35dffba133b43af79533:/src/common/ipcbase.cpp diff --git a/src/common/ipcbase.cpp b/src/common/ipcbase.cpp index 759727e1b5..1d5075cb25 100644 --- a/src/common/ipcbase.cpp +++ b/src/common/ipcbase.cpp @@ -30,10 +30,10 @@ IMPLEMENT_CLASS(wxServerBase, wxObject) IMPLEMENT_CLASS(wxClientBase, wxObject) IMPLEMENT_CLASS(wxConnectionBase, wxObject) -wxConnectionBase::wxConnectionBase(wxChar *buffer, int size) +wxConnectionBase::wxConnectionBase(wxChar *buffer, int bytes) : m_connected(true), m_buffer(buffer), - m_buffersize(size), + m_buffersize(bytes), m_deletebufferwhendone(false) { if ( buffer == (wxChar *)NULL ) @@ -80,7 +80,10 @@ wxChar *wxConnectionBase::GetBufferAtLeast( size_t bytes ) { // we're in charge of buffer, increase it if ( m_buffer ) delete m_buffer; - m_buffer = new wxChar[bytes]; + // the argument specifies **byte size**, but m_buffer is of type + // wxChar. Under unicode: sizeof(wxChar) > 1, so the buffer size is + // bytes / sizeof(wxChar) rounded upwards. + m_buffer = new wxChar[(bytes + sizeof(wxChar) - 1) / sizeof(wxChar)]; m_buffersize = bytes; return m_buffer; } // user-supplied buffer, fail