When recv returns 0, the connection has been remotely closed or dropped. Changes are to Read [ modified patch 1303565 ] and Select [ patch 1283936 ]
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@35802 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -882,7 +882,13 @@ int GSocket::Read(char *buffer, int size)
|
|||||||
else
|
else
|
||||||
ret = Recv_Dgram(buffer, size);
|
ret = Recv_Dgram(buffer, size);
|
||||||
|
|
||||||
if (ret == -1) {
|
/* If recv returned zero, then the connection is lost, and errno is not set.
|
||||||
|
* Otherwise, recv has returned an error (-1), in which case we have lost the
|
||||||
|
* socket only if errno does _not_ indicate that there may be more data to read.
|
||||||
|
*/
|
||||||
|
if (ret == 0)
|
||||||
|
m_error = GSOCK_IOERR;
|
||||||
|
else if (ret == -1) {
|
||||||
if ((errno == EWOULDBLOCK) || (errno == EAGAIN))
|
if ((errno == EWOULDBLOCK) || (errno == EAGAIN))
|
||||||
m_error = GSOCK_WOULDBLOCK;
|
m_error = GSOCK_WOULDBLOCK;
|
||||||
else
|
else
|
||||||
@@ -1026,7 +1032,12 @@ GSocketEventFlags GSocket::Select(GSocketEventFlags flags)
|
|||||||
result |= GSOCK_CONNECTION_FLAG;
|
result |= GSOCK_CONNECTION_FLAG;
|
||||||
m_detected |= GSOCK_CONNECTION_FLAG;
|
m_detected |= GSOCK_CONNECTION_FLAG;
|
||||||
}
|
}
|
||||||
else if ((errno != EWOULDBLOCK) && (errno != EAGAIN) && (errno != EINTR))
|
/* If recv returned zero, then the connection is lost, and errno is not set.
|
||||||
|
* Otherwise, recv has returned an error (-1), in which case we have lost the
|
||||||
|
* socket only if errno does _not_ indicate that there may be more data to read.
|
||||||
|
*/
|
||||||
|
else if (num == 0 ||
|
||||||
|
(errno != EWOULDBLOCK) && (errno != EAGAIN) && (errno != EINTR))
|
||||||
{
|
{
|
||||||
m_detected = GSOCK_LOST_FLAG;
|
m_detected = GSOCK_LOST_FLAG;
|
||||||
m_establishing = false;
|
m_establishing = false;
|
||||||
|
Reference in New Issue
Block a user