summaryrefslogtreecommitdiffhomepage
path: root/src/class.c
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2019-05-15 15:47:02 +0900
committerGitHub <[email protected]>2019-05-15 15:47:02 +0900
commit7f1f499b2277c4636824b7f3e9b301576aaddba5 (patch)
tree1c0487cfdbd16f7fe3b83a8d0d9c82bf96133bca /src/class.c
parent780342eddb880a1c0a457311b005398ce36d0c9f (diff)
parentcc7f9190ba93ef45bf85a7278dffe6326cf620a3 (diff)
downloadmruby-7f1f499b2277c4636824b7f3e9b301576aaddba5.tar.gz
mruby-7f1f499b2277c4636824b7f3e9b301576aaddba5.zip
Merge pull request #4400 from shuujii/fix-name-assignment-to-frozen-anonymous-class-module
Fix name assignment to frozen anonymous class/module
Diffstat (limited to 'src/class.c')
-rw-r--r--src/class.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/src/class.c b/src/class.c
index 2cabc820e..9d26851b9 100644
--- a/src/class.c
+++ b/src/class.c
@@ -66,15 +66,15 @@ mrb_class_name_class(mrb_state *mrb, struct RClass *outer, struct RClass *c, mrb
name = mrb_class_path(mrb, outer);
if (mrb_nil_p(name)) { /* unnamed outer class */
if (outer != mrb->object_class && outer != c) {
- mrb_obj_iv_set(mrb, (struct RObject*)c, mrb_intern_lit(mrb, "__outer__"),
- mrb_obj_value(outer));
+ mrb_obj_iv_set_force(mrb, (struct RObject*)c, mrb_intern_lit(mrb, "__outer__"),
+ mrb_obj_value(outer));
}
return;
}
mrb_str_cat_cstr(mrb, name, "::");
mrb_str_cat_cstr(mrb, name, mrb_sym2name(mrb, id));
}
- mrb_obj_iv_set(mrb, (struct RObject*)c, nsym, name);
+ mrb_obj_iv_set_force(mrb, (struct RObject*)c, nsym, name);
}
static void