aboutsummaryrefslogtreecommitdiff
path: root/winsup/cygwin/net.cc
diff options
context:
space:
mode:
authorCorinna Vinschen <corinna@vinschen.de>2004-04-01 10:36:40 +0000
committerCorinna Vinschen <corinna@vinschen.de>2004-04-01 10:36:40 +0000
commit4cfacffa795c41e117a02c21741a0868168f3a10 (patch)
tree8a608c829f1a0286dc209bbefec18bd245a33f40 /winsup/cygwin/net.cc
parent4fc406c935d3896553e5f925e271428f92996d3c (diff)
downloadnewlib-4cfacffa795c41e117a02c21741a0868168f3a10.zip
newlib-4cfacffa795c41e117a02c21741a0868168f3a10.tar.gz
newlib-4cfacffa795c41e117a02c21741a0868168f3a10.tar.bz2
* net.cc (wsock_event::wait): Make wsa_err an int. Don't set
ret to 0 if any error has happened.
Diffstat (limited to 'winsup/cygwin/net.cc')
-rw-r--r--winsup/cygwin/net.cc13
1 files changed, 8 insertions, 5 deletions
diff --git a/winsup/cygwin/net.cc b/winsup/cygwin/net.cc
index 2459580..4f8ee3d 100644
--- a/winsup/cygwin/net.cc
+++ b/winsup/cygwin/net.cc
@@ -69,7 +69,7 @@ int
wsock_event::wait (int sock, int &closed)
{
int ret = SOCKET_ERROR;
- DWORD wsa_err = 0;
+ int wsa_err = 0;
WSAEVENT ev[2] = { event, signal_arrived };
switch (WSAWaitForMultipleEvents (2, ev, FALSE, WSA_INFINITE, FALSE))
{
@@ -94,10 +94,13 @@ wsock_event::wait (int sock, int &closed)
if (evts.lNetworkEvents & FD_CLOSE)
{
closed = 1;
- if (!wsa_err && evts.iErrorCode[FD_CLOSE_BIT])
- wsa_err = evts.iErrorCode[FD_CLOSE_BIT];
- else
- ret = 0;
+ if (!wsa_err)
+ {
+ if (evts.iErrorCode[FD_CLOSE_BIT])
+ wsa_err = evts.iErrorCode[FD_CLOSE_BIT];
+ else
+ ret = 0;
+ }
}
if (wsa_err)
WSASetLastError (wsa_err);