diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2017-08-01 16:25:09 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2017-08-01 16:25:09 +0900 |
| commit | 648e9ea51ba6c058ccec725af0ada5c8dd7e9197 (patch) | |
| tree | ebb22d75c71165efb3215013aa3d4316b8bb6478 /src | |
| parent | 3f6a098626d95ef59f566dad4afbef83249e9334 (diff) | |
| download | mruby-648e9ea51ba6c058ccec725af0ada5c8dd7e9197.tar.gz mruby-648e9ea51ba6c058ccec725af0ada5c8dd7e9197.zip | |
Move naming unnamed classes/modules
From `mrb_mod_const_set` to `mrb_const_set`.
Diffstat (limited to 'src')
| -rw-r--r-- | src/class.c | 9 | ||||
| -rw-r--r-- | src/variable.c | 12 |
2 files changed, 13 insertions, 8 deletions
diff --git a/src/class.c b/src/class.c index 54754092e..df7258ac0 100644 --- a/src/class.c +++ b/src/class.c @@ -2208,14 +2208,7 @@ mrb_mod_const_set(mrb_state *mrb, mrb_value mod) mrb_get_args(mrb, "no", &id, &value); check_const_name_sym(mrb, id); - if ((mrb_type(value) == MRB_TT_CLASS || mrb_type(value) == MRB_TT_MODULE) - && !mrb_obj_iv_defined(mrb, mrb_obj_ptr(value), mrb_intern_lit(mrb, "__classid__"))) { - /* name unnamed classes/modules */ - setup_class(mrb, mrb_class_ptr(mod), mrb_class_ptr(value), id); - } - else { - mrb_const_set(mrb, mod, id, value); - } + mrb_const_set(mrb, mod, id, value); return value; } diff --git a/src/variable.c b/src/variable.c index 9f4b2e728..b700081a5 100644 --- a/src/variable.c +++ b/src/variable.c @@ -869,7 +869,19 @@ mrb_vm_const_get(mrb_state *mrb, mrb_sym sym) MRB_API void mrb_const_set(mrb_state *mrb, mrb_value mod, mrb_sym sym, mrb_value v) { + mrb_sym id = mrb_intern_lit(mrb, "__classid__"); + mod_const_check(mrb, mod); + if ((mrb_type(v) == MRB_TT_CLASS || mrb_type(v) == MRB_TT_MODULE) + && !mrb_obj_iv_defined(mrb, mrb_obj_ptr(v), id)) { + struct RObject *c = mrb_obj_ptr(v); + + /* name unnamed classes/modules */ + mrb_obj_iv_set(mrb, c, id, mrb_symbol_value(sym)); + if (mrb_class_ptr(mod) != mrb->object_class) { + mrb_obj_iv_set(mrb, c, mrb_intern_lit(mrb, "__outer__"), mod); + } + } mrb_iv_set(mrb, mod, sym, v); } |
