Issue #9356 has been updated by Usaku NAKAMURA.

ruby -v changed from ruby 2.1.0p0 (2013-12-25 revision 44422) [x86_64-darwin13.0] to -

 Hi,
 
 In message "[ruby-core:60819] [ruby-trunk - Bug #9356] TCPSocket.new does not seem to handle INTR"
     on Feb.18,2014 18:34:40, <shugo / ruby-lang.org> wrote:
 > Does anybody know why the following code in ext/socket/init.c is necessary?
 > 
 >             if (sockerr == 0)
 >                 continue;       /* workaround for winsock */
 
 It was introduced at r7931 by me (9 years ago!),
 but I forgot the reason.
 If my comment of those days is believed, we may wrap it
 with #ifdef_WIN32.
 
 
 Regards,
 -- 
 U.Nakamura <usa / garbagecollect.jp>

----------------------------------------
Bug #9356: TCPSocket.new does not seem to handle INTR
https://bugs.ruby-lang.org/issues/9356#change-45237

* Author: Charlie Somerville
* Status: Open
* Priority: Normal
* Assignee: 
* Category: 
* Target version: 
* ruby -v: -
* Backport: 1.9.3: UNKNOWN, 2.0.0: UNKNOWN, 2.1: UNKNOWN
----------------------------------------
TCPSocket.new does not seem to handle EINTR properly.

In the attached test script, I try to open a TCP connection to my server and make an HTTP request while a background thread continually sends a signal to the process.

This causes the #write call to fail with:

x.rb:13:in `write': Socket is not connected (Errno::ENOTCONN)
	from x.rb:13:in `<main>'

This also appears to affect 2.0.0. 1.9.3 is unaffected.

---Files--------------------------------
socket-eintr.rb (207 Bytes)


-- 
http://bugs.ruby-lang.org/