X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/375abe3dac3d7816738ccd1ab495d9a0441550d4..c49245f8baabd69afd7302c43474d3bdd247fb89:/src/common/sckstrm.cpp diff --git a/src/common/sckstrm.cpp b/src/common/sckstrm.cpp index 8dde4ba92e..df93922870 100644 --- a/src/common/sckstrm.cpp +++ b/src/common/sckstrm.cpp @@ -16,12 +16,15 @@ #include "wx/wxprec.h" #ifdef __BORLANDC__ -#pragma hdrstop + #pragma hdrstop #endif #ifndef WX_PRECOMP + #include "wx/defs.h" #endif +#if wxUSE_SOCKETS && wxUSE_STREAMS + #include "wx/stream.h" #include "wx/socket.h" #include "wx/sckstrm.h" @@ -39,15 +42,21 @@ wxSocketOutputStream::~wxSocketOutputStream() { } -wxOutputStream& wxSocketOutputStream::Write(const void *buffer, size_t size) -{ - m_lastcount = m_o_socket->Write((const char *)buffer, size).LastCount(); - return *this; -} - size_t wxSocketOutputStream::OnSysWrite(const void *buffer, size_t size) { - return m_o_socket->Write((const char *)buffer, size).LastCount(); + size_t ret; + + ret = m_o_socket->Write((const char *)buffer, size).LastCount(); + switch (m_o_socket->LastError()) { + case GSOCK_NOERROR: + m_lasterror = wxStream_NOERROR; + break; + default: + m_lasterror = wxStream_READ_ERR; + break; + } + return ret; + } // --------------------------------------------------------------------------- @@ -63,15 +72,20 @@ wxSocketInputStream::~wxSocketInputStream() { } -wxInputStream& wxSocketInputStream::Read(void *buffer, size_t size) -{ - m_lastcount = m_i_socket->Read((char *)buffer, size).LastCount(); - return *this; -} - size_t wxSocketInputStream::OnSysRead(void *buffer, size_t size) { - return m_i_socket->Read((char *)buffer, size).LastCount(); + size_t ret; + + ret = m_i_socket->Read((char *)buffer, size).LastCount(); + switch (m_i_socket->LastError()) { + case GSOCK_NOERROR: + m_lasterror = wxStream_NOERROR; + break; + default: + m_lasterror = wxStream_WRITE_ERR; + break; + } + return ret; } // --------------------------------------------------------------------------- @@ -86,3 +100,6 @@ wxSocketStream::wxSocketStream(wxSocketBase& s) wxSocketStream::~wxSocketStream() { } + +#endif + // wxUSE_STREAMS && wxUSE_SOCKETS