summaryrefslogtreecommitdiff
path: root/win32
diff options
context:
space:
mode:
authorusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-07-11 16:55:14 +0000
committerusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-07-11 16:55:14 +0000
commitdde090583006604fe9eeb84a4c8793bf32311b7a (patch)
tree5f4cd4da24a295798681167ec3e60d0f8c829dbc /win32
parentdfd0d6a5ca865d589f943f57c29f2a6a6e2260d6 (diff)
downloadruby-dde090583006604fe9eeb84a4c8793bf32311b7a.tar.gz
* win32/win32.c (rb_w32_select): shoudn't pass non-socket handle to
original select(). git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@18033 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'win32')
-rw-r--r--win32/win32.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/win32/win32.c b/win32/win32.c
index d3ba3fa07b..11774cda16 100644
--- a/win32/win32.c
+++ b/win32/win32.c
@@ -2150,6 +2150,7 @@ rb_w32_select(int nfds, fd_set *rd, fd_set *wr, fd_set *ex,
fd_set cons_rd;
fd_set else_rd;
fd_set else_wr;
+ fd_set except;
int nonsock = 0;
if (nfds < 0 || (timeout && (timeout->tv_sec < 0 || timeout->tv_usec < 0))) {
@@ -2178,6 +2179,9 @@ rb_w32_select(int nfds, fd_set *rd, fd_set *wr, fd_set *ex,
else_wr.fd_count = 0;
nonsock += extract_fd(&else_wr, wr, is_not_socket);
+ except.fd_count = 0;
+ extract_fd(&except, ex, is_not_socket); // drop only
+
r = 0;
if (rd && rd->fd_count > r) r = rd->fd_count;
if (wr && wr->fd_count > r) r = wr->fd_count;