summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-08-25 15:37:04 +0000
committerakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-08-25 15:37:04 +0000
commit6c1190d10f4cb338595a39237e0126a8b677c8db (patch)
tree079e3277c9bc3504fc211a4cca9c891511ea5c9f
parent86154f63b358fe81441be9d339d6dba0054f8c92 (diff)
* io.c (io_fwrite): add TEXTMODE_NEWLINE_ENCODER to option for
rb_str_transcode. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@18851 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--io.c7
2 files changed, 11 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 61e95b794e..bc27f8b68c 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Tue Aug 26 00:36:01 2008 Tanaka Akira <akr@fsij.org>
+
+ * io.c (io_fwrite): add TEXTMODE_NEWLINE_ENCODER to option for
+ rb_str_transcode.
+
Tue Aug 26 00:24:23 2008 Tanaka Akira <akr@fsij.org>
* transcode.c (make_econv_exception): show readagain part for invalid
diff --git a/io.c b/io.c
index 6ca2f71f59..b06016d091 100644
--- a/io.c
+++ b/io.c
@@ -755,7 +755,12 @@ io_fwrite(VALUE str, rb_io_t *fptr)
}
if (!NIL_P(common_encoding)) {
- str = rb_str_transcode(str, common_encoding, &fptr->encs.opts);
+ rb_econv_option_t ecopts = fptr->encs.opts;
+#ifdef TEXTMODE_NEWLINE_ENCODER
+ if (NEED_NEWLINE_ENCODER(fptr))
+ ecopts.flags |= TEXTMODE_NEWLINE_ENCODER;
+#endif
+ str = rb_str_transcode(str, common_encoding, &ecopts);
}
if (fptr->writeconv) {