summaryrefslogtreecommitdiffstats
path: root/encoding.c
diff options
context:
space:
mode:
authoryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-08-08 15:35:29 +0000
committeryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-08-08 15:35:29 +0000
commit18474514cf2c3d1fcf0e6993bd94c226fcd149c7 (patch)
treefac255f8ec7aab86f5ddc690bb6206ed43f8ca77 /encoding.c
parentd3554dba41442ecad7bb8387ad35c72e7f09710b (diff)
merges r24425 from trunk into ruby_1_9_1.
-- * encoding.c (rb_enc_associate_index): cannot set encoding on special constants. git-svn-id: http://svn.ruby-lang.org/repos/ruby/branches/ruby_1_9_1@24474 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'encoding.c')
-rw-r--r--encoding.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/encoding.c b/encoding.c
index faebdfac8..bc960c26a 100644
--- a/encoding.c
+++ b/encoding.c
@@ -617,6 +617,9 @@ rb_enc_associate_index(VALUE obj, int idx)
/* enc_check_capable(obj);*/
if (rb_enc_get_index(obj) == idx)
return obj;
+ if (SPECIAL_CONST_P(obj)) {
+ rb_raise(rb_eArgError, "cannot set encoding");
+ }
if (!ENC_CODERANGE_ASCIIONLY(obj) ||
!rb_enc_asciicompat(rb_enc_from_index(idx))) {
ENC_CODERANGE_CLEAR(obj);