summaryrefslogtreecommitdiff
path: root/io.c
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-12-21 03:29:54 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-12-21 03:29:54 +0000
commit74a0c0cc7e7664402ae08fb6ae47e8b8db78b5be (patch)
treee591fa4926c871997984f388be05a765bebb534e /io.c
parente613c7cf5fed9bca9ccf98b045c45596508bd4e0 (diff)
* io.c (rb_io_mode_enc): set default external encoding if no
encoding specified explicitly. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@14389 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'io.c')
-rw-r--r--io.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/io.c b/io.c
index e07845fb31..89d15cac8d 100644
--- a/io.c
+++ b/io.c
@@ -3068,6 +3068,9 @@ rb_io_mode_enc(rb_io_t *fptr, const char *mode)
}
#endif
}
+ else if (!(fptr->mode & FMODE_BINMODE)) {
+ fptr->enc = rb_default_external_encoding();
+ }
}
struct sysopen_struct {
@@ -3188,8 +3191,8 @@ rb_file_open_internal(VALUE io, const char *fname, const char *mode)
rb_io_t *fptr;
MakeOpenFile(io, fptr);
- rb_io_mode_enc(fptr, mode);
fptr->mode = rb_io_mode_flags(mode);
+ rb_io_mode_enc(fptr, mode);
fptr->path = strdup(fname);
fptr->fd = rb_sysopen(fptr->path, rb_io_mode_modenum(rb_io_flags_mode(fptr->mode)), 0666);
io_check_tty(fptr);
@@ -3498,10 +3501,10 @@ pipe_open(const char *cmd, int argc, VALUE *argv, const char *mode)
port = io_alloc(rb_cIO);
MakeOpenFile(port, fptr);
- rb_io_mode_enc(fptr, mode);
fptr->fd = fd;
fptr->stdio_file = fp;
fptr->mode = modef | FMODE_SYNC|FMODE_DUPLEX;
+ rb_io_mode_enc(fptr, mode);
fptr->pid = pid;
if (0 <= write_fd) {