diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2017-03-19 00:21:53 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2017-03-19 00:28:52 +0900 |
| commit | 2cbbeba0e091e95bc8456c29f6cab2c36b44a86b (patch) | |
| tree | c9493d05c5c35eac7279d283d9a13e91f027cadb /src/vm.c | |
| parent | 75c374cad330e2c99ceb7e1ca083523a7651e753 (diff) | |
| download | mruby-2cbbeba0e091e95bc8456c29f6cab2c36b44a86b.tar.gz mruby-2cbbeba0e091e95bc8456c29f6cab2c36b44a86b.zip | |
Check call depth when mrb_yield_class() is called; ref #3521
Diffstat (limited to 'src/vm.c')
| -rw-r--r-- | src/vm.c | 3 |
1 files changed, 3 insertions, 0 deletions
@@ -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; |
