diff --git a/ChangeLog b/ChangeLog index 2ea24a45de..1141d128c7 100644 --- a/ChangeLog +++ b/ChangeLog @@ -5193,6 +5193,11 @@ Wed Sep 8 15:19:49 2004 Hidetoshi NAGAI * ext/tk/lib/tk/text.rb: add TkText#clear and erase +Tue Sep 7 15:17:49 2004 Nobuyoshi Nakada + + * ext/socket/socket.c (ruby_connect): break immediately if a + socket is non-blocking. [ruby-talk:111654] + Mon Sep 6 11:08:50 2004 Hirokazu Yamamoto * ext/tk/lib/tk/menu.rb(TkOptionMenubutton#insert): call correct method diff --git a/ext/socket/socket.c b/ext/socket/socket.c index 68ceb284fe..ec3eb0d453 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);