diff options
| author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-01-18 04:49:14 +0000 |
|---|---|---|
| committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-01-18 04:49:14 +0000 |
| commit | e9836b1b460e6839fda2256517d925b43a2c6d71 (patch) | |
| tree | 3af118754c56e22801f2c733c2aa3c6da3b3e299 /string.c | |
| parent | ea393a2ea2b3193b9583f4ff19d08622cb317233 (diff) | |
| download | ruby-e9836b1b460e6839fda2256517d925b43a2c6d71.tar.gz ruby-e9836b1b460e6839fda2256517d925b43a2c6d71.tar.xz ruby-e9836b1b460e6839fda2256517d925b43a2c6d71.zip | |
* string.c (rb_str_dump): preserve the encoding of source string
if it is ASCII compatible. otherwise, add '.force_encoding()'
for ugly work around. maybe we should implement some other way
to keep non ASCII encoding in dumped string. [ruby-dev:33142]
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@15108 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'string.c')
| -rw-r--r-- | string.c | 11 |
1 files changed, 10 insertions, 1 deletions
@@ -3210,6 +3210,7 @@ escape_codepoint: VALUE rb_str_dump(VALUE str) { + rb_encoding *enc0 = rb_enc_get(str); rb_encoding *enc = rb_enc_from_index(0); long len; char *p, *pend; @@ -3242,6 +3243,10 @@ rb_str_dump(VALUE str) break; } } + if (!rb_enc_asciicompat(enc0)) { + len += 19; /* ".force_encoding('')" */ + len += strlen(enc0->name); + } result = rb_str_new5(str, 0, len); p = RSTRING_PTR(str); pend = p + RSTRING_LEN(str); @@ -3301,10 +3306,14 @@ rb_str_dump(VALUE str) } } *q++ = '"'; + if (!rb_enc_asciicompat(enc0)) { + sprintf(q, ".force_encoding(\"%s\")", enc0->name); + enc0 = enc; + } OBJ_INFECT(result, str); /* result from dump is ASCII */ - rb_enc_associate(result, enc); + rb_enc_associate(result, enc0); return result; } |
