diff options
author | akr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-09-06 03:26:35 +0000 |
---|---|---|
committer | akr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-09-06 03:26:35 +0000 |
commit | 393f57670fa5dd8ee09ed3fd2fefbb709ec3e874 (patch) | |
tree | 2ecbf6b7d658170b3118a32064b9452398422e00 | |
parent | 091171a28654801c533166d1819ec7e1705a53ac (diff) | |
download | ruby-393f57670fa5dd8ee09ed3fd2fefbb709ec3e874.tar.gz |
* transcode.c (stateless_encoding_i): ignore supplemental conversions.
Encoding::Converter.stateless_encoding("html-attr-escaped") should be
nil.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@19174 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-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; |