diff options
| author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-06-16 14:46:53 +0000 |
|---|---|---|
| committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-06-16 14:46:53 +0000 |
| commit | 06d72d17ef2a8c8ad82a6d9e70d9cef23f5cd919 (patch) | |
| tree | 0e7c410a6ff6ad6f0c522287b255f9939e89ab9e | |
| parent | 6050c8951436a12edfa1b97f9b1b3464fb8f81fd (diff) | |
| download | ruby-06d72d17ef2a8c8ad82a6d9e70d9cef23f5cd919.tar.gz ruby-06d72d17ef2a8c8ad82a6d9e70d9cef23f5cd919.tar.xz ruby-06d72d17ef2a8c8ad82a6d9e70d9cef23f5cd919.zip | |
* io.c (fptr_finalize): revert last change. [ruby-dev:38648]
* io.c (fptr_finalize): skip close(2) for fd 0,1,2.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@23705 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
| -rw-r--r-- | ChangeLog | 6 | ||||
| -rw-r--r-- | io.c | 6 |
2 files changed, 9 insertions, 3 deletions
@@ -1,3 +1,9 @@ +Tue Jun 16 22:47:37 2009 Yukihiro Matsumoto <matz@ruby-lang.org> + + * io.c (fptr_finalize): revert last change. [ruby-dev:38648] + + * io.c (fptr_finalize): skip close(2) for fd 0,1,2. + Tue Jun 16 20:07:09 2009 NARUSE, Yui <naruse@ruby-lang.org> * transcode.c (transcode_restartable0): refix can't build with VC9. @@ -3221,8 +3221,8 @@ fptr_finalize(rb_io_t *fptr, int noraise) if (io_fflush(fptr) < 0 && NIL_P(err)) err = noraise ? Qtrue : INT2NUM(errno); } - if (noraise && (IS_PREP_STDIO(fptr) || fptr->fd <= 2)) { - goto check_err; + if (IS_PREP_STDIO(fptr) || fptr->fd <= 2) { + goto skip_fd_close; } if (fptr->stdio_file) { /* fptr->stdio_file is deallocated anyway @@ -3237,11 +3237,11 @@ fptr_finalize(rb_io_t *fptr, int noraise) if (close(fptr->fd) < 0 && NIL_P(err)) err = noraise ? Qtrue : INT2NUM(errno); } + skip_fd_close: fptr->fd = -1; fptr->stdio_file = 0; fptr->mode &= ~(FMODE_READABLE|FMODE_WRITABLE); - check_err: if (!NIL_P(err) && !noraise) { switch(TYPE(err)) { case T_FIXNUM: |
