diff options
author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-10-08 23:49:22 +0000 |
---|---|---|
committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-10-08 23:49:22 +0000 |
commit | 22c8e88b413d1ad2fb10a74aebc6b2a803abf0a8 (patch) | |
tree | a3d8dd0a3d44c32322dfcbc2633ff66349cef55f | |
parent | 43f77aaf1a9ea21e7386d40dd3ea3369caa1adc0 (diff) |
* thread.c (rb_thread_wait_fd_rw): should not block by select if
there's only one thread living. fixed [ruby-dev:36646].
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@19719 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | thread.c | 1 |
2 files changed, 6 insertions, 0 deletions
@@ -1,3 +1,8 @@ +Thu Oct 9 08:47:38 2008 Yukihiro Matsumoto <matz@ruby-lang.org> + + * thread.c (rb_thread_wait_fd_rw): should not block by select if + there's only one thread living. fixed [ruby-dev:36646]. + Wed Oct 8 20:59:52 2008 Masaki Suketa <masaki.suketa@nifty.ne.jp> * ext/win32ole/win32ole.c (ole_init_cp): initialize WIN32OLE.codepage @@ -2235,6 +2235,7 @@ rb_thread_wait_fd_rw(int fd, int read) if (fd < 0) { rb_raise(rb_eIOError, "closed stream"); } + if (rb_thread_alone()) return; while (result <= 0) { rb_fdset_t set; rb_fd_init(&set); |