diff options
author | akr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-11-28 16:31:12 +0000 |
---|---|---|
committer | akr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-11-28 16:31:12 +0000 |
commit | 06646d1b4ebf73e54b444bee43df76f3ff490f31 (patch) | |
tree | fd9bdf090f862a83a1a1a6988704ed8035dd7135 | |
parent | 44b9ca66968f7d683d0356c8cec123100c27345a (diff) | |
download | ruby-06646d1b4ebf73e54b444bee43df76f3ff490f31.tar.gz |
* io.c (rb_io_check_writable): restrict io_seek by
READ_DATA_PENDING because io_seek(fptr, 0, SEEK_CUR) is
meaningful only if read buffer is not empty.
call io_seek regardless of NEED_IO_SEEK_BETWEEN_RW.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@7404 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 7 | ||||
-rw-r--r-- | io.c | 5 |
2 files changed, 9 insertions, 3 deletions
@@ -1,3 +1,10 @@ +Mon Nov 29 01:18:18 2004 Tanaka Akira <akr@m17n.org> + + * io.c (rb_io_check_writable): restrict io_seek by + READ_DATA_PENDING because io_seek(fptr, 0, SEEK_CUR) is + meaningful only if read buffer is not empty. + call io_seek regardless of NEED_IO_SEEK_BETWEEN_RW. + Sun Nov 28 15:57:58 2004 Kouhei Sutou <kou@cozmixng.org> * lib/rss/rss.rb (RSS::Element#tag): not use block_given? for @@ -261,11 +261,10 @@ rb_io_check_writable(fptr) if (!(fptr->mode & FMODE_WRITABLE)) { rb_raise(rb_eIOError, "not opened for writing"); } -#if NEED_IO_SEEK_BETWEEN_RW - if ((fptr->mode & FMODE_RBUF) && !feof(fptr->f) && !fptr->f2) { + if ((fptr->mode & FMODE_RBUF) && !feof(fptr->f) && !fptr->f2 && + READ_DATA_PENDING(fptr->f)) { io_seek(fptr, 0, SEEK_CUR); } -#endif if (!fptr->f2) { fptr->mode &= ~FMODE_RBUF; } |