summaryrefslogtreecommitdiff
path: root/object.c
diff options
context:
space:
mode:
authorakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-04-04 13:26:39 +0000
committerakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-04-04 13:26:39 +0000
commita4587840cc2b002321af227ee2cb315a94158d67 (patch)
tree84b83c13ab9f388bc0cc0b50608f045b8897df4c /object.c
parentc3d1fde2b528413f5be2f936a9d7ea899a777fc7 (diff)
* object.c (rb_mod_cvar_set): Reverted "avoid inadvertent
symbol creation" to avoid SEGV by Class.new.class_variable_set(1, 2). git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@40108 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'object.c')
-rw-r--r--object.c18
1 files changed, 4 insertions, 14 deletions
diff --git a/object.c b/object.c
index 8ee6d033a4..6861525e8e 100644
--- a/object.c
+++ b/object.c
@@ -2296,21 +2296,11 @@ rb_mod_cvar_get(VALUE obj, VALUE iv)
static VALUE
rb_mod_cvar_set(VALUE obj, VALUE iv, VALUE val)
{
- ID id;
+ ID id = rb_to_id(iv);
- if (SYMBOL_P(iv)) {
- id = SYM2ID(iv);
- if (!rb_is_class_id(id)) {
- rb_name_error(id, "`%"PRIsVALUE"' is not allowed as an class variable name",
- QUOTE_ID(id));
- }
- }
- else if (!rb_is_class_id(iv)) {
- rb_name_error_str(iv, "`%"PRIsVALUE"' is not allowed as a class variable name",
- QUOTE(iv));
- }
- else {
- id = rb_to_id(iv);
+ if (!rb_is_class_id(id)) {
+ rb_name_error(id, "`%"PRIsVALUE"' is not allowed as a class variable name",
+ QUOTE_ID(id));
}
rb_cvar_set(obj, id, val);
return val;