From 7f0c5beb6f53cc057c03c74e15468282b1e52cd5 Mon Sep 17 00:00:00 2001 From: akr Date: Fri, 15 Aug 2008 09:33:59 +0000 Subject: [PATCH] * include/ruby/encoding.h (rb_econv_t): add error_tc in last_error. * transcode.c (rb_econv_convert): fill error_tc. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@18644 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 6 ++++++ include/ruby/encoding.h | 1 + transcode.c | 12 +++++++----- 3 files changed, 14 insertions(+), 5 deletions(-) diff --git a/ChangeLog b/ChangeLog index 6a1f240c98..30436afb06 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,9 @@ +Fri Aug 15 18:33:22 2008 Tanaka Akira + + * include/ruby/encoding.h (rb_econv_t): add error_tc in last_error. + + * transcode.c (rb_econv_convert): fill error_tc. + Fri Aug 15 18:10:49 2008 Tanaka Akira * include/ruby/encoding.h (rb_econv_t): new field: last_error. diff --git a/include/ruby/encoding.h b/include/ruby/encoding.h index 675bd5d90d..e4259845e8 100644 --- a/include/ruby/encoding.h +++ b/include/ruby/encoding.h @@ -227,6 +227,7 @@ typedef struct { /* last error */ struct { rb_econv_result_t result; + struct rb_transcoding *error_tc; const char *source_encoding; const char *destination_encoding; const unsigned char *error_bytes_start; diff --git a/transcode.c b/transcode.c index 92d9ec62fc..a814eb9888 100644 --- a/transcode.c +++ b/transcode.c @@ -950,11 +950,13 @@ rb_econv_convert(rb_econv_t *ec, ec->last_error.partial_input = flags & ECONV_PARTIAL_INPUT; if (res == econv_invalid_byte_sequence || res == econv_undefined_conversion) { - ec->last_error.source_encoding = ec->elems[result_position].tc->transcoder->from_encoding; - ec->last_error.destination_encoding = ec->elems[result_position].tc->transcoder->to_encoding; - ec->last_error.error_bytes_start = TRANSCODING_READBUF(ec->elems[result_position].tc); - ec->last_error.error_bytes_len = ec->elems[result_position].tc->recognized_len; - ec->last_error.readagain_len = ec->elems[result_position].tc->readagain_len; + rb_transcoding *error_tc = ec->elems[result_position].tc; + ec->last_error.error_tc = error_tc; + ec->last_error.source_encoding = error_tc->transcoder->from_encoding; + ec->last_error.destination_encoding = error_tc->transcoder->to_encoding; + ec->last_error.error_bytes_start = TRANSCODING_READBUF(error_tc); + ec->last_error.error_bytes_len = error_tc->recognized_len; + ec->last_error.readagain_len = error_tc->readagain_len; } return res;