diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2019-05-15 15:47:02 +0900 |
|---|---|---|
| committer | GitHub <[email protected]> | 2019-05-15 15:47:02 +0900 |
| commit | 7f1f499b2277c4636824b7f3e9b301576aaddba5 (patch) | |
| tree | 1c0487cfdbd16f7fe3b83a8d0d9c82bf96133bca /src/class.c | |
| parent | 780342eddb880a1c0a457311b005398ce36d0c9f (diff) | |
| parent | cc7f9190ba93ef45bf85a7278dffe6326cf620a3 (diff) | |
| download | mruby-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.c | 6 |
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 |
