aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ChangeLog6
-rw-r--r--test/ruby/test_econv.rb1
-rw-r--r--transcode.c8
3 files changed, 14 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 54cdac37dc..646a983fd4 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -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;