summaryrefslogtreecommitdiffstats
path: root/win/tclWinSock.c
diff options
context:
space:
mode:
authorferrieux <ferrieux@users.sourceforge.net>2009-04-27 21:36:33 (GMT)
committerferrieux <ferrieux@users.sourceforge.net>2009-04-27 21:36:33 (GMT)
commit18cc34b4b4357e640bce38edb0bb3442058cf563 (patch)
treee780be80beced9b577a40c34efa98c5326695b76 /win/tclWinSock.c
parent5524a7bbef637a5dfd39cf199e79efae784204e8 (diff)
downloadtcl-18cc34b4b4357e640bce38edb0bb3442058cf563.zip
tcl-18cc34b4b4357e640bce38edb0bb3442058cf563.tar.gz
tcl-18cc34b4b4357e640bce38edb0bb3442058cf563.tar.bz2
Backport fix for [Bug 2446662]: resync Win behavior on RST with that of unix (EOF).
Diffstat (limited to 'win/tclWinSock.c')
-rw-r--r--win/tclWinSock.c16
1 files changed, 14 insertions, 2 deletions
diff --git a/win/tclWinSock.c b/win/tclWinSock.c
index ff94767..8e2612e 100644
--- a/win/tclWinSock.c
+++ b/win/tclWinSock.c
@@ -8,7 +8,7 @@
* See the file "license.terms" for information on usage and redistribution of
* this file, and for a DISCLAIMER OF ALL WARRANTIES.
*
- * RCS: @(#) $Id: tclWinSock.c,v 1.62 2008/02/22 11:50:54 patthoyts Exp $
+ * RCS: @(#) $Id: tclWinSock.c,v 1.62.2.1 2009/04/27 21:36:34 ferrieux Exp $
*/
#include "tclWinInt.h"
@@ -1574,11 +1574,23 @@ TcpInputProc(
break;
}
+ error = WSAGetLastError();
+
+ /*
+ * If an RST comes, then ignore the error and report an EOF just like
+ * on unix.
+ */
+
+ if (error == WSAECONNRESET) {
+ infoPtr->flags |= SOCKET_EOF;
+ bytesRead = 0;
+ break;
+ }
+
/*
* Check for error condition or underflow in non-blocking case.
*/
- error = WSAGetLastError();
if ((infoPtr->flags & SOCKET_ASYNC) || (error != WSAEWOULDBLOCK)) {
TclWinConvertWSAError(error);
*errorCodePtr = Tcl_GetErrno();