summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2013-03-15 09:12:05 -0700
committerYukihiro "Matz" Matsumoto <[email protected]>2013-03-15 09:12:05 -0700
commit26926a1d52b595b99ffa26d6dfdce3526b16cb41 (patch)
tree976564bd806c164bb2b437164b6eda5ebf44458b
parent618d7339f198fb9692719641e363d2da9378e651 (diff)
parent5aafbca0e4769ca93ae088ec83f1ec6007e169a7 (diff)
downloadmruby-26926a1d52b595b99ffa26d6dfdce3526b16cb41.tar.gz
mruby-26926a1d52b595b99ffa26d6dfdce3526b16cb41.zip
Merge pull request #1013 from takkaw/fix_bo_missing
fix segmentation fault in BasicObject#inspect
-rw-r--r--src/class.c9
1 files changed, 7 insertions, 2 deletions
diff --git a/src/class.c b/src/class.c
index 6f83e997e..59431c26e 100644
--- a/src/class.c
+++ b/src/class.c
@@ -1139,8 +1139,13 @@ mrb_bob_missing(mrb_state *mrb, mrb_value mod)
mrb_raise(mrb, E_TYPE_ERROR, "name should be a symbol");
}
- inspect = mrb_funcall(mrb, mod, "inspect", 0);
- if (RSTRING_LEN(inspect) > 64) {
+ if (mrb_respond_to(mrb,mod,mrb_intern(mrb,"inspect"))){
+ inspect = mrb_funcall(mrb, mod, "inspect", 0);
+ if (RSTRING_LEN(inspect) > 64) {
+ inspect = mrb_any_to_s(mrb, mod);
+ }
+ }
+ else {
inspect = mrb_any_to_s(mrb, mod);
}