aboutsummaryrefslogtreecommitdiffstats
path: root/win32
diff options
context:
space:
mode:
authorusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-11-19 04:59:50 +0000
committerusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-11-19 04:59:50 +0000
commit01a54cf40faa7eac714eea2f92c4cbfd76a52ca7 (patch)
treeb9fa7bb9b8e81cd20171eb54fe01d5319e2731d7 /win32
parent8a3423d38b611aeececc832f7b92e0657cd09e5a (diff)
downloadruby-01a54cf40faa7eac714eea2f92c4cbfd76a52ca7.tar.gz
* win32/win32.c (finish_overlapped_socket): ignore EMSGSIZE when input,
because POSIX platforms just do so. fixes test errors revealed by r52647. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@52662 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'win32')
-rw-r--r--win32/win32.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/win32/win32.c b/win32/win32.c
index 953c916c93..6ebd9e433c 100644
--- a/win32/win32.c
+++ b/win32/win32.c
@@ -3276,8 +3276,13 @@ finish_overlapped_socket(BOOL input, SOCKET s, WSAOVERLAPPED *wol, int result, D
default:
if ((err = WSAGetLastError()) == WSAECONNABORTED && !input)
errno = EPIPE;
+ else if (err == WSAEMSGSIZE && input) {
+ result = TRUE;
+ *len = size;
+ break;
+ }
else
- errno = map_errno(WSAGetLastError());
+ errno = map_errno(err);
/* thru */
case WAIT_OBJECT_0 + 1:
/* interrupted */