diff options
author | usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-08-03 07:30:19 +0000 |
---|---|---|
committer | usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-08-03 07:30:19 +0000 |
commit | fe038100d98e5352139367627809c17f1773f9c9 (patch) | |
tree | 02c71fef2a5d64355c6968cda9cc57c29c5b4a3e | |
parent | 9997227af889127eb1af4298e485708c4be3b367 (diff) | |
download | ruby-fe038100d98e5352139367627809c17f1773f9c9.tar.gz |
* win32/win32.c (rb_w32_connect): return value was broken when some
error occurred.
[ruby-core:24234]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@24367 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 6 | ||||
-rw-r--r-- | win32/win32.c | 11 |
2 files changed, 10 insertions, 7 deletions
@@ -1,3 +1,9 @@ +Mon Aug 3 16:28:09 2009 NAKAMURA Usaku <usa@ruby-lang.org> + + * win32/win32.c (rb_w32_connect): return value was broken when some + error occurred. + [ruby-core:24234] + Mon Aug 3 15:56:52 2009 Nobuyoshi Nakada <nobu@ruby-lang.org> * array.c (permute0): use chars for boolean array. diff --git a/win32/win32.c b/win32/win32.c index b98575572b..8f2a4ac8fa 100644 --- a/win32/win32.c +++ b/win32/win32.c @@ -2591,14 +2591,11 @@ rb_w32_connect(int s, const struct sockaddr *addr, int addrlen) RUBY_CRITICAL({ r = connect(TO_SOCKET(s), addr, addrlen); if (r == SOCKET_ERROR) { - r = WSAGetLastError(); - if (r != WSAEWOULDBLOCK) { - errno = map_errno(r); - } - else { + int err = WSAGetLastError(); + if (err != WSAEWOULDBLOCK) + errno = map_errno(err); + else errno = EINPROGRESS; - r = -1; - } } }); return r; |