// Created: 04/01/98
// RCS-ID: $Id$
// Copyright: (c) Julian Smart
-// Licence: wxWindows licence
+// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
-#ifdef __GNUG__
-#pragma implementation "ipcbase.h"
-#endif
-
// For compilers that support precompilation, includes "wx.h".
#include "wx/wxprec.h"
IMPLEMENT_CLASS(wxClientBase, wxObject)
IMPLEMENT_CLASS(wxConnectionBase, wxObject)
-wxConnectionBase::wxConnectionBase(wxChar *buffer, int size)
- : m_connected(TRUE),
+wxConnectionBase::wxConnectionBase(wxChar *buffer, int bytes)
+ : m_connected(true),
m_buffer(buffer),
- m_buffersize(size),
- m_deletebufferwhendone(FALSE)
+ m_buffersize(bytes),
+ m_deletebufferwhendone(false)
{
if ( buffer == (wxChar *)NULL )
{ // behave like next constructor
m_buffersize = 0;
- m_deletebufferwhendone = TRUE;
+ m_deletebufferwhendone = true;
}
}
wxConnectionBase::wxConnectionBase()
- : m_connected(TRUE),
+ : m_connected(true),
m_buffer(NULL),
m_buffersize(0),
- m_deletebufferwhendone(TRUE)
+ m_deletebufferwhendone(true)
{
}
-wxConnectionBase::wxConnectionBase(wxConnectionBase& copy)
- : m_connected(copy.m_connected),
+wxConnectionBase::wxConnectionBase(const wxConnectionBase& copy)
+ : wxObject(),
+ m_connected(copy.m_connected),
m_buffer(copy.m_buffer),
m_buffersize(copy.m_buffersize),
- m_deletebufferwhendone(FALSE)
+ m_deletebufferwhendone(false)
{
// copy constructor would require ref-counted pointer to buffer
{ // need to resize buffer
if ( m_deletebufferwhendone )
{ // we're in charge of buffer, increase it
- if ( !m_buffer )
+ 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