diff options
| author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-12-25 06:55:38 +0000 |
|---|---|---|
| committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-12-25 06:55:38 +0000 |
| commit | e176e67b7fd97d2528e42b48303a2d38c10f2507 (patch) | |
| tree | 6cc0ff13be0974ec0029fa567bf8936d526cf534 /io.c | |
| parent | 11ebb0d1e3c11197f12a81adc497b8defb085bc3 (diff) | |
| download | ruby-e176e67b7fd97d2528e42b48303a2d38c10f2507.tar.gz ruby-e176e67b7fd97d2528e42b48303a2d38c10f2507.tar.xz ruby-e176e67b7fd97d2528e42b48303a2d38c10f2507.zip | |
* io.c (io_fflush): flush write buffer without write lock in
finalizers. [ruby-dev:37572]
* io.c (rb_io_fptr_finalize): clear write lock before finalizing.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@20988 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'io.c')
| -rw-r--r-- | io.c | 9 |
1 files changed, 8 insertions, 1 deletions
@@ -558,7 +558,13 @@ io_fflush(rb_io_t *fptr) retry: if (fptr->wbuf_len == 0) return 0; - r = rb_mutex_synchronize(fptr->write_lock, io_flush_buffer, (VALUE)fptr); + if (fptr->write_lock) { + r = rb_mutex_synchronize(fptr->write_lock, io_flush_buffer, (VALUE)fptr); + } + else { + long l = io_writable_length(fptr, fptr->wbuf_len); + r = rb_write_internal(fptr->fd, fptr->wbuf+fptr->wbuf_off, l); + } /* xxx: Other threads may modify wbuf. * A lock is required, definitely. */ rb_io_check_closed(fptr); @@ -3190,6 +3196,7 @@ rb_io_fptr_finalize(rb_io_t *fptr) { if (!fptr) return 0; fptr->pathv = Qnil; + fptr->write_lock = 0; if (0 <= fptr->fd) rb_io_fptr_cleanup(fptr, Qtrue); if (fptr->rbuf) { |
