summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-02-06 14:46:21 +0000
committerakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-02-06 14:46:21 +0000
commit3449b28698b06b170315c8e261c43b391fbaf076 (patch)
treef9d8fe1a54f53bc0f4d6a40a4b25d105502c4579
parent41b4d50dcc153f7642f41cd4e873e66caf6e6d8b (diff)
downloadruby-3449b28698b06b170315c8e261c43b391fbaf076.tar.gz
ruby-3449b28698b06b170315c8e261c43b391fbaf076.tar.xz
ruby-3449b28698b06b170315c8e261c43b391fbaf076.zip
* io.c (io_fread): use rb_io_wait_readable for retry
avoid Errno::EINTR on ruby -e 'trap(:CHLD) {}; spawn("sleep 1"); STDIN.read' git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@22099 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--io.c3
2 files changed, 8 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog
index 94e19536c..ca5d60edc 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Fri Feb 6 23:28:33 2009 Tanaka Akira <akr@fsij.org>
+
+ * io.c (io_fread): use rb_io_wait_readable for retry
+ avoid Errno::EINTR on ruby -e 'trap(:CHLD) {}; spawn("sleep 1"); STDIN.read'
+
Fri Feb 6 22:36:11 2009 Alexander Zavorine <alexandre.zavorine@nokia.com>
* thread_pthread.c (native_thread_create) [__SYMBIAN32__]: reduced pthread stack size.
diff --git a/io.c b/io.c
index 21d775076..edfcdd646 100644
--- a/io.c
+++ b/io.c
@@ -1442,12 +1442,15 @@ io_fread(VALUE str, long offset, rb_io_t *fptr)
if (READ_DATA_PENDING(fptr) == 0) {
while (n > 0) {
+ again:
c = rb_read_internal(fptr->fd, RSTRING_PTR(str)+offset, n);
if (c == 0) {
io_set_eof(fptr);
break;
}
if (c < 0) {
+ if (rb_io_wait_readable(fptr->fd))
+ goto again;
rb_sys_fail_path(fptr->pathv);
}
offset += c;