summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2017-03-19 00:21:53 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2017-03-19 00:28:52 +0900
commit2cbbeba0e091e95bc8456c29f6cab2c36b44a86b (patch)
treec9493d05c5c35eac7279d283d9a13e91f027cadb /src
parent75c374cad330e2c99ceb7e1ca083523a7651e753 (diff)
downloadmruby-2cbbeba0e091e95bc8456c29f6cab2c36b44a86b.tar.gz
mruby-2cbbeba0e091e95bc8456c29f6cab2c36b44a86b.zip
Check call depth when mrb_yield_class() is called; ref #3521
Diffstat (limited to 'src')
-rw-r--r--src/vm.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/src/vm.c b/src/vm.c
index e860cf9fd..3e40cecb0 100644
--- a/src/vm.c
+++ b/src/vm.c
@@ -668,6 +668,9 @@ mrb_yield_with_class(mrb_state *mrb, mrb_value b, mrb_int argc, const mrb_value
if (mrb_nil_p(b)) {
mrb_raise(mrb, E_ARGUMENT_ERROR, "no block given");
}
+ if (mrb->c->ci - mrb->c->cibase > MRB_FUNCALL_DEPTH_MAX) {
+ mrb_exc_raise(mrb, mrb_obj_value(mrb->stack_err));
+ }
p = mrb_proc_ptr(b);
ci = cipush(mrb);
ci->mid = mid;