diff options
| author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2005-07-28 01:51:59 +0000 |
|---|---|---|
| committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2005-07-28 01:51:59 +0000 |
| commit | 8d5d5e068643008e04b6adb877c66471390c48aa (patch) | |
| tree | 611df0acbbe30201c8cf43d1fc0ea86e1f7015be /ext/socket/socket.c | |
| parent | b0d4f9bc0bd4f0374e28dd0509d83b377e19e504 (diff) | |
| download | ruby-8d5d5e068643008e04b6adb877c66471390c48aa.tar.gz ruby-8d5d5e068643008e04b6adb877c66471390c48aa.tar.xz ruby-8d5d5e068643008e04b6adb877c66471390c48aa.zip | |
* ext/socket/socket.c (ruby_connect): break immediately if a
socket is non-blocking. [ruby-talk:111654]
git-svn-id: http://svn.ruby-lang.org/repos/ruby/branches/ruby_1_8@8853 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'ext/socket/socket.c')
| -rw-r--r-- | ext/socket/socket.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/ext/socket/socket.c b/ext/socket/socket.c index 68ceb284f..ec3eb0d45 100644 --- a/ext/socket/socket.c +++ b/ext/socket/socket.c @@ -929,7 +929,9 @@ ruby_connect(fd, sockaddr, len, socks) int socks; { int status; +#if defined(HAVE_FCNTL) int mode; +#endif #if WAIT_IN_PROGRESS > 0 int wait_in_progress = -1; int sockerr, sockerrlen; @@ -973,6 +975,9 @@ ruby_connect(fd, sockaddr, len, socks) #ifdef EINPROGRESS case EINPROGRESS: #endif +#if defined(HAVE_FCNTL) + if (mode & NONBLOCKING) break; +#endif #if WAIT_IN_PROGRESS > 0 sockerrlen = sizeof(sockerr); status = getsockopt(fd, SOL_SOCKET, SO_ERROR, (void *)&sockerr, &sockerrlen); |
