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/variable.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/variable.c')
| -rw-r--r-- | src/variable.c | 21 |
1 files changed, 12 insertions, 9 deletions
diff --git a/src/variable.c b/src/variable.c index c4c9d369f..ee21a3b96 100644 --- a/src/variable.c +++ b/src/variable.c @@ -341,21 +341,24 @@ mrb_iv_get(mrb_state *mrb, mrb_value obj, mrb_sym sym) static inline void assign_class_name(mrb_state *mrb, struct RObject *obj, mrb_sym sym, mrb_value v); -MRB_API void -mrb_obj_iv_set(mrb_state *mrb, struct RObject *obj, mrb_sym sym, mrb_value v) +void +mrb_obj_iv_set_force(mrb_state *mrb, struct RObject *obj, mrb_sym sym, mrb_value v) { - iv_tbl *t; - - mrb_check_frozen(mrb, obj); assign_class_name(mrb, obj, sym, v); if (!obj->iv) { obj->iv = iv_new(mrb); } - t = obj->iv; - iv_put(mrb, t, sym, v); + iv_put(mrb, obj->iv, sym, v); mrb_write_barrier(mrb, (struct RBasic*)obj); } +MRB_API void +mrb_obj_iv_set(mrb_state *mrb, struct RObject *obj, mrb_sym sym, mrb_value v) +{ + mrb_check_frozen(mrb, obj); + mrb_obj_iv_set_force(mrb, obj, sym, v); +} + /* Iterates over the instance variable table. */ MRB_API void mrb_iv_foreach(mrb_state *mrb, mrb_value obj, mrb_iv_foreach_func *func, void *p) @@ -385,10 +388,10 @@ assign_class_name(mrb_state *mrb, struct RObject *obj, mrb_sym sym, mrb_value v) if (mrb_nil_p(o)) { if ((struct RClass *)obj == mrb->object_class) { - mrb_obj_iv_set(mrb, c, id_classname, mrb_symbol_value(sym)); + mrb_obj_iv_set_force(mrb, c, id_classname, mrb_symbol_value(sym)); } else { - mrb_obj_iv_set(mrb, c, id_outer, mrb_obj_value(obj)); + mrb_obj_iv_set_force(mrb, c, id_outer, mrb_obj_value(obj)); } } } |
