size_t wxSocketOutputStream::OnSysWrite(const void *buffer, size_t size)
{
- const char *buf = (const char *)buffer;
- size_t count = 0;
-
- while ( count < size && m_o_socket->WaitForWrite() )
- {
- const size_t ret = m_o_socket->Write(buf, size - count).LastCount();
-
- buf += ret;
- count += ret;
-
- if ( m_o_socket->Error() )
- {
- if (m_o_socket->LastError() != wxSOCKET_WOULDBLOCK)
- {
- m_lasterror = wxSTREAM_WRITE_ERROR;
- return count;
- }
- }
- }
-
- m_lasterror = wxSTREAM_NO_ERROR;
- return count;
+ const size_t ret = m_o_socket->Write(buffer, size).LastCount();
+ m_lasterror = m_o_socket->Error()
+ ? m_o_socket->IsClosed() ? wxSTREAM_EOF
+ : wxSTREAM_WRITE_ERROR
+ : wxSTREAM_NO_ERROR;
+ return ret;
}
// ---------------------------------------------------------------------------
size_t wxSocketInputStream::OnSysRead(void *buffer, size_t size)
{
- char *buf = (char *)buffer;
- size_t count = 0;
-
- while ( count < size && m_i_socket->WaitForRead() )
- {
- const size_t ret = m_i_socket->Read(buf, size - count).LastCount();
-
- buf += ret;
- count += ret;
-
- if ( m_i_socket->Error() )
- {
- if (m_i_socket->LastError() != wxSOCKET_WOULDBLOCK)
- {
- m_lasterror = wxSTREAM_READ_ERROR;
- return count;
- }
- }
- }
-
- m_lasterror = wxSTREAM_NO_ERROR;
- return count;
+ const size_t ret = m_i_socket->Read(buffer, size).LastCount();
+ m_lasterror = m_i_socket->Error()
+ ? m_i_socket->IsClosed() ? wxSTREAM_EOF
+ : wxSTREAM_READ_ERROR
+ : wxSTREAM_NO_ERROR;
+ return ret;
}
// ---------------------------------------------------------------------------
{
}
-#endif
- // wxUSE_STREAMS && wxUSE_SOCKETS
+#endif // wxUSE_STREAMS && wxUSE_SOCKETS