diff options
| author | KOBAYASHI Shuji <[email protected]> | 2019-04-23 20:45:38 +0900 |
|---|---|---|
| committer | KOBAYASHI Shuji <[email protected]> | 2019-04-23 20:45:38 +0900 |
| commit | cc7f9190ba93ef45bf85a7278dffe6326cf620a3 (patch) | |
| tree | eeec7f6fa7152d8a04d8e401c44e9e825774498d /src/class.c | |
| parent | 7cf1bc39a7184e92b0fe534e610b288accc61e5a (diff) | |
| download | mruby-cc7f9190ba93ef45bf85a7278dffe6326cf620a3.tar.gz mruby-cc7f9190ba93ef45bf85a7278dffe6326cf620a3.zip | |
Fix name assignment to frozen anonymous class/module
Fix the following issues:
A = Class.new.freeze #=> FrozenError
Module.new::B = Class.new.freeze #=> FrozenError
String::B = Module.new.freeze #=> FrozenError
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 d6efdbdc4..77ff04437 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 |
