]> git.saurik.com Git - wxWidgets.git/blobdiff - src/common/ipcbase.cpp
Added some const qualifiers.
[wxWidgets.git] / src / common / ipcbase.cpp
index 5ec21ae5741f746c497490253b71410ac9edd69e..9d7c3dab2940cbd1a16260a50b8c355de7fe1c94 100644 (file)
@@ -30,4 +30,54 @@ IMPLEMENT_CLASS(wxServerBase, wxObject)
 IMPLEMENT_CLASS(wxClientBase, wxObject)
 IMPLEMENT_CLASS(wxConnectionBase, wxObject)
 
+wxConnectionBase::wxConnectionBase(wxChar *buffer, int size)
+  : m_buffer(buffer), m_buffersize(size),
+    m_deletebufferwhendone(false), m_connected(true)
+{
+  if ( buffer == (wxChar *)NULL )
+  { // behave like next constructor
+    m_buffersize = 0;
+    m_deletebufferwhendone = true;
+  }
+}
+
+wxConnectionBase::wxConnectionBase()
+  : m_buffersize(0), m_buffer(NULL), m_deletebufferwhendone(true),
+    m_connected(true)
+{
+}
+
+wxConnectionBase::wxConnectionBase(wxConnectionBase& copy)
+  : m_buffer(copy.m_buffer), m_buffersize(copy.m_buffersize),
+    m_deletebufferwhendone(false), m_connected(copy.m_connected)
+{
+  // copy constructor would require ref-counted pointer to buffer
+  wxFAIL_MSG( _T("Copy constructor of wxConnectionBase not implemented") );
+}
+
+
+wxConnectionBase::~wxConnectionBase(void)
+{
+  if ( m_deletebufferwhendone && m_buffer )
+   delete m_buffer;
+}
+
+wxChar *wxConnectionBase::GetBufferAtLeast( size_t bytes )
+{
+  if ( m_buffersize >= bytes )
+    return m_buffer;
+  else
+  {  // need to resize buffer
+    if ( m_deletebufferwhendone )
+    { // we're in charge of buffer, increase it
+      if ( !m_buffer )
+        delete m_buffer;
+      m_buffer = new wxChar[bytes];
+      m_buffersize = bytes;
+      return m_buffer;
+    } // user-supplied buffer, fail
+    else
+      return NULL;
+  }
+}