diff options
| author | Christopher Aue <[email protected]> | 2017-08-22 11:24:46 +0200 |
|---|---|---|
| committer | Christopher Aue <[email protected]> | 2017-08-23 15:18:06 +0200 |
| commit | 64e5208404d37326c071506d861b8bd9776218df (patch) | |
| tree | d8d3f77de90f14e982048aca049f3dcc25a24ece /src | |
| parent | 4c9a60487799b923ff905def46cb2497bcc1e4dd (diff) | |
| download | mruby-64e5208404d37326c071506d861b8bd9776218df.tar.gz mruby-64e5208404d37326c071506d861b8bd9776218df.zip | |
Asserted bidx < ci->nregs for OP_SEND and OP_SUPER
Diffstat (limited to 'src')
| -rw-r--r-- | src/vm.c | 6 |
1 files changed, 5 insertions, 1 deletions
@@ -1333,10 +1333,12 @@ RETRY_TRY_BLOCK: int bidx = (argc < 0) ? a+2 : a+n+1; struct RProc *m; struct RClass *c; - mrb_callinfo *ci; + mrb_callinfo *ci = mrb->c->ci; mrb_value recv, blk; mrb_sym mid = syms[GETARG_B(i)]; + mrb_assert(bidx < ci->nregs); + recv = regs[a]; if (GET_OPCODE(i) != OP_SENDB) { SET_NIL_VALUE(regs[bidx]); @@ -1523,6 +1525,8 @@ RETRY_TRY_BLOCK: mrb_value recv, blk; mrb_sym mid = ci->mid; + mrb_assert(bidx < ci->nregs); + if (mid == 0 || !ci->target_class) { mrb_value exc = mrb_exc_new_str_lit(mrb, E_NOMETHOD_ERROR, "super called outside of method"); mrb_exc_set(mrb, exc); |
