diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2003-06-26 18:24:58 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2003-06-26 18:24:58 +0000 |
commit | 7a425f71e38df08a35d0d416b508bd5c95ed5fa6 (patch) | |
tree | 3ba10893d2e9cca6d1a2b197e191bd1ea1eb208d /io.c | |
parent | 894d2b643d67ffa9919208327146911e56020ad4 (diff) |
* io.c (io_fflush): need to check if closed after thread switch.
[ruby-dev:20351]
* io.c (fptr_finalize): ditto.
* string.c (rb_str_rindex_m): fixed wrong fix. should move backward
first only when matching from the end.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@4006 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'io.c')
-rw-r--r-- | io.c | 6 |
1 files changed, 5 insertions, 1 deletions
@@ -301,7 +301,9 @@ io_fflush(f, fptr) { int n; - rb_thread_fd_writable(fileno(f)); + if (!rb_thread_fd_writable(fileno(f))) { + rb_io_check_closed(fptr); + } for (;;) { TRAP_BEG; n = fflush(f); @@ -1331,6 +1333,7 @@ fptr_finalize(fptr, noraise) e = errno; break; } + if (!fptr->f2) break; } fptr->f2 = 0; } @@ -1339,6 +1342,7 @@ fptr_finalize(fptr, noraise) while ((n1 = fclose(fptr->f)) < 0) { if (f2 != -1 || !(fptr->mode & FMODE_WBUF)) break; if (!rb_io_wait_writable(f1)) break; + if (!fptr->f) break; } fptr->f = 0; if (n1 < 0 && errno == EBADF && f1 == f2) { |