aboutsummaryrefslogtreecommitdiffstats
path: root/ext
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2005-07-28 02:33:28 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2005-07-28 02:33:28 +0000
commit989b0a6d1e327900f20fcd9b898393b9edbd0c2e (patch)
tree0e46afe1c792d9adcc4cb8e628cc906f20919cfa /ext
parentbd3404ced0af1a368e070b6c0fde63290a3e54a8 (diff)
downloadruby-989b0a6d1e327900f20fcd9b898393b9edbd0c2e.tar.gz
* parse.y (f_larglist): allow bv_decl at the end of lambda
argument list. [EXPERIMENTAL] * parse.y (new_bv_gen): allow local variable shadowing, with warning in verbose mode. * ext/socket/socket.c (ruby_connect): break immediately if a socket is non-blocking. [ruby-talk:111654] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@8855 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'ext')
-rw-r--r--ext/socket/socket.c8
1 files changed, 7 insertions, 1 deletions
diff --git a/ext/socket/socket.c b/ext/socket/socket.c
index b512839626..b870677aab 100644
--- a/ext/socket/socket.c
+++ b/ext/socket/socket.c
@@ -916,7 +916,8 @@ wait_connectable0(fd, fds_w, fds_e)
int fd;
rb_fdset_t *fds_w, *fds_e;
{
- int sockerr, sockerrlen;
+ int sockerr;
+ socklen_t sockerrlen;
for (;;) {
rb_fd_zero(fds_w);
@@ -1011,7 +1012,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;
@@ -1055,6 +1058,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);