diff options
| author | take_cheeze <[email protected]> | 2014-06-28 00:45:47 +0900 |
|---|---|---|
| committer | take_cheeze <[email protected]> | 2014-06-28 00:45:47 +0900 |
| commit | f9076230f2193a3fe2b30b795bd828a7479eba38 (patch) | |
| tree | 59ecb38d97ec87304723a7abd08e3cf171f86f6c /mrbgems/mruby-objectspace/src/mruby_objectspace.c | |
| parent | 919af61766b1d06cd0e747c1d6257ada14c09eff (diff) | |
| download | mruby-f9076230f2193a3fe2b30b795bd828a7479eba38.tar.gz mruby-f9076230f2193a3fe2b30b795bd828a7479eba38.zip | |
Fix crash in method call in `ObjectSpace.each_object` block.
* Filter `MRB_TT_ENV` and `MRB_TT_ICLASS`.
* Set `mrb->string_class` in `mrb_init_exception` instead.
Diffstat (limited to 'mrbgems/mruby-objectspace/src/mruby_objectspace.c')
| -rw-r--r-- | mrbgems/mruby-objectspace/src/mruby_objectspace.c | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/mrbgems/mruby-objectspace/src/mruby_objectspace.c b/mrbgems/mruby-objectspace/src/mruby_objectspace.c index ba22fc990..8c7452c1e 100644 --- a/mrbgems/mruby-objectspace/src/mruby_objectspace.c +++ b/mrbgems/mruby-objectspace/src/mruby_objectspace.c @@ -119,6 +119,13 @@ os_each_object_cb(mrb_state *mrb, struct RBasic *obj, void *ud) return; } + /* filter internal objects */ + switch (obj->tt) { + case MRB_TT_ENV: + case MRB_TT_ICLASS: + return; + } + /* filter class kind if target module defined */ if (d->target_module && !mrb_obj_is_kind_of(mrb, mrb_obj_value(obj), d->target_module)) { return; |
