From f88c9f03f7c00402558f5b47331774b8b65fbaaa Mon Sep 17 00:00:00 2001 From: akr Date: Sat, 6 Sep 2008 10:54:59 +0000 Subject: [PATCH] * transcode.c (rb_econv_open): fix last_tc. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@19186 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 4 ++++ transcode.c | 7 +++---- 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 + + * transcode.c (rb_econv_open): fix last_tc. + Sat Sep 6 19:36:34 2008 Tanaka Akira * 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;