diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-06-21 01:46:37 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-06-21 01:46:37 +0000 |
commit | 3448160b248e92b2c0c2a39ba42a9d9c366b4e72 (patch) | |
tree | 1b3f0620472f84ad7cc5feae00a301747d4c30d8 | |
parent | 29313aa3200007e23561a2f862fa74e0bf58aca4 (diff) |
* transcode.c (enc_arg): default interanl encoding may not be set.
[ruby-core:23932]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@23773 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | transcode.c | 4 |
2 files changed, 7 insertions, 2 deletions
@@ -1,3 +1,8 @@ +Sun Jun 21 10:46:32 2009 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * transcode.c (enc_arg): default interanl encoding may not be set. + [ruby-core:23932] + Sat Jun 20 21:11:43 2009 Tadayoshi Funaba <tadf@dotrb.org> * numeric.c (num_div): don't use num_floor which is actually diff --git a/transcode.c b/transcode.c index 7fb25601fc..ee6794d9be 100644 --- a/transcode.c +++ b/transcode.c @@ -2470,13 +2470,13 @@ enc_arg(volatile VALUE *arg, const char **name_p, rb_encoding **enc_p) int encidx; VALUE encval; - if ((encidx = rb_to_encoding_index(encval = *arg)) < 0) { + if (((encidx = rb_to_encoding_index(encval = *arg)) < 0) || + !(enc = rb_enc_from_index(encidx))) { enc = NULL; encidx = 0; n = StringValueCStr(*arg); } else { - enc = rb_enc_from_index(encidx); n = rb_enc_name(enc); } |