summaryrefslogtreecommitdiff
path: root/transcode.c
diff options
context:
space:
mode:
authorakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-09-06 03:26:35 +0000
committerakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-09-06 03:26:35 +0000
commit393f57670fa5dd8ee09ed3fd2fefbb709ec3e874 (patch)
tree2ecbf6b7d658170b3118a32064b9452398422e00 /transcode.c
parent091171a28654801c533166d1819ec7e1705a53ac (diff)
* 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
Diffstat (limited to 'transcode.c')
-rw-r--r--transcode.c8
1 files changed, 7 insertions, 1 deletions
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;