summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog4
-rw-r--r--transcode.c7
2 files changed, 7 insertions, 4 deletions
diff --git a/ChangeLog b/ChangeLog
index 83bd015cdb..ec8ad6e6f6 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+Sat Sep 6 19:54:25 2008 Tanaka Akira <akr@fsij.org>
+
+ * transcode.c (rb_econv_open): fix last_tc.
+
Sat Sep 6 19:36:34 2008 Tanaka Akira <akr@fsij.org>
* io.c (rb_io_binmode): clear newline flags in writeconv_pre_ecflags.
diff --git a/transcode.c b/transcode.c
index a0bac4f9d5..e2ea56a3ba 100644
--- a/transcode.c
+++ b/transcode.c
@@ -880,7 +880,6 @@ rb_econv_open(const char *sname, const char *dname, int ecflags)
transcoder_entry_t **entries = NULL;
int num_trans;
static rb_econv_t *ec;
- int universal_newline_decoder_added = 0;
rb_encoding *senc, *denc;
int sidx, didx;
@@ -977,9 +976,9 @@ rb_econv_open(const char *sname, const char *dname, int ecflags)
ec->last_tc = NULL;
ec->last_trans_index = -1;
}
- else if (universal_newline_decoder_added) {
- ec->last_tc = ec->elems[ec->num_trans-2].tc;
- ec->last_trans_index = ec->num_trans-2;
+ else {
+ ec->last_trans_index = ec->num_trans-1-num_decoders;
+ ec->last_tc = ec->elems[ec->last_trans_index].tc;
}
return ec;