diff options
-rw-r--r-- | ChangeLog | 6 | ||||
-rw-r--r-- | test/ruby/test_econv.rb | 1 | ||||
-rw-r--r-- | transcode.c | 8 |
3 files changed, 14 insertions, 1 deletions
@@ -1,3 +1,9 @@ +Sat Sep 6 12:25:31 2008 Tanaka Akira <akr@fsij.org> + + * transcode.c (stateless_encoding_i): ignore supplemental conversions. + Encoding::Converter.stateless_encoding("html-attr-escaped") should be + nil. + Sat Sep 6 12:19:36 2008 Tanaka Akira <akr@fsij.org> * enc/trans/escape.trans (escape_html_attr_init): new function. diff --git a/test/ruby/test_econv.rb b/test/ruby/test_econv.rb index 49ba2ae9d3..4e4608c1af 100644 --- a/test/ruby/test_econv.rb +++ b/test/ruby/test_econv.rb @@ -34,6 +34,7 @@ class TestEncodingConverter < Test::Unit::TestCase assert_nil(Encoding::Converter.stateless_encoding("UTF-8")) assert_nil(Encoding::Converter.stateless_encoding("UTF-16BE")) assert_nil(Encoding::Converter.stateless_encoding(Encoding::UTF_8)) + assert_nil(Encoding::Converter.stateless_encoding("html-attr-escaped")) end def test_stateless_encoding_iso2022jp diff --git a/transcode.c b/transcode.c index 3dbdb44d1c..5c9e7d8264 100644 --- a/transcode.c +++ b/transcode.c @@ -133,6 +133,8 @@ struct rb_econv_t { * Dispatch data and logic */ +#define SUPPLEMENTAL_CONVERSION(sname, dname) (*(sname) == '\0' || *(dname) == '\0') + typedef struct { const char *sname; const char *dname; @@ -1635,7 +1637,11 @@ stateless_encoding_i(st_data_t key, st_data_t val, st_data_t arg) if (st_lookup(table2, (st_data_t)data->stateful_enc, &v)) { transcoder_entry_t *entry = (transcoder_entry_t *)v; - const rb_transcoder *tr = load_transcoder_entry(entry); + const rb_transcoder *tr; + if (SUPPLEMENTAL_CONVERSION(entry->sname, entry->dname)) { + return ST_CONTINUE; + } + tr = load_transcoder_entry(entry); if (tr && tr->stateful_type == stateful_encoder) { data->stateless_enc = tr->src_encoding; return ST_STOP; |