diff options
author | akr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-09-23 12:51:39 +0000 |
---|---|---|
committer | akr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-09-23 12:51:39 +0000 |
commit | c1759a9f18bf7349d7d8165b625deda5be5d20ca (patch) | |
tree | a792ef9e548a1b1f46bae72cf0b8785a6ed576b2 | |
parent | 0f1a1073f7c9ab1ac67975ec45faa8fe91c22671 (diff) | |
download | ruby-c1759a9f18bf7349d7d8165b625deda5be5d20ca.tar.gz |
* io.c (io_binwrite): allocate wbuf if nosync.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@19493 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 4 | ||||
-rw-r--r-- | io.c | 2 |
2 files changed, 5 insertions, 1 deletions
@@ -1,3 +1,7 @@ +Tue Sep 23 21:50:53 2008 Tanaka Akira <akr@fsij.org> + + * io.c (io_binwrite): allocate wbuf if nosync. + Tue Sep 23 21:45:02 2008 Tanaka Akira <akr@fsij.org> * io.c (copy_stream_body): use io_binwrite instead of io_fwrite. @@ -751,7 +751,7 @@ io_binwrite(VALUE str, rb_io_t *fptr, int nosync) len = RSTRING_LEN(str); if ((n = len) <= 0) return n; - if (fptr->wbuf == NULL && !(fptr->mode & FMODE_SYNC)) { + if (fptr->wbuf == NULL && !(!nosync && (fptr->mode & FMODE_SYNC))) { fptr->wbuf_off = 0; fptr->wbuf_len = 0; fptr->wbuf_capa = 8192; |