summaryrefslogtreecommitdiffhomepage
path: root/src/error.c
diff options
context:
space:
mode:
authortake_cheeze <[email protected]>2014-06-28 00:45:47 +0900
committertake_cheeze <[email protected]>2014-06-28 00:45:47 +0900
commitf9076230f2193a3fe2b30b795bd828a7479eba38 (patch)
tree59ecb38d97ec87304723a7abd08e3cf171f86f6c /src/error.c
parent919af61766b1d06cd0e747c1d6257ada14c09eff (diff)
downloadmruby-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 'src/error.c')
-rw-r--r--src/error.c8
1 files changed, 3 insertions, 5 deletions
diff --git a/src/error.c b/src/error.c
index dcb6063f8..01feecefd 100644
--- a/src/error.c
+++ b/src/error.c
@@ -91,15 +91,10 @@ static mrb_value
exc_to_s(mrb_state *mrb, mrb_value exc)
{
mrb_value mesg = mrb_attr_get(mrb, exc, mrb_intern_lit(mrb, "mesg"));
- struct RObject *p;
if (!mrb_string_p(mesg)) {
return mrb_str_new_cstr(mrb, mrb_obj_classname(mrb, exc));
}
- p = mrb_obj_ptr(mesg);
- if (!p->c) {
- p->c = mrb->string_class;
- }
return mesg;
}
@@ -441,6 +436,9 @@ mrb_init_exception(mrb_state *mrb)
{
struct RClass *exception, *runtime_error, *script_error;
+ /* initialize mrb->string_class before creating RString object for nomem_err */
+ mrb->string_class = mrb_define_class(mrb, "String", mrb->object_class);
+
mrb->eException_class = exception = mrb_define_class(mrb, "Exception", mrb->object_class); /* 15.2.22 */
mrb_define_class_method(mrb, exception, "exception", mrb_instance_new, MRB_ARGS_ANY());
mrb_define_method(mrb, exception, "exception", exc_exception, MRB_ARGS_ANY());