diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2017-02-13 18:18:09 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2017-02-13 18:18:09 +0900 |
| commit | f198530444f4b5ebfd011c3287114951c8553e5e (patch) | |
| tree | b7c0a9859a8794b8d56af43cd347ce9e7cff2292 | |
| parent | b23874777d5b59fb61342485f90915a5b623b400 (diff) | |
| download | mruby-f198530444f4b5ebfd011c3287114951c8553e5e.tar.gz mruby-f198530444f4b5ebfd011c3287114951c8553e5e.zip | |
Fixed too much value_copy() when block is not given; fix #3440
The issue was reported by https://hackerone.com/titanous
| -rw-r--r-- | src/vm.c | 16 |
1 files changed, 12 insertions, 4 deletions
@@ -1151,12 +1151,14 @@ RETRY_TRY_BLOCK: } if (GET_OPCODE(i) != OP_SENDB) { SET_NIL_VALUE(regs[bidx]); + bidx = 0; } else { mrb_value blk = regs[bidx]; if (!mrb_nil_p(blk) && mrb_type(blk) != MRB_TT_PROC) { regs[bidx] = mrb_convert_type(mrb, blk, MRB_TT_PROC, "Proc", "to_proc"); } + bidx = 1; } c = mrb_class(mrb, recv); m = mrb_method_search_vm(mrb, &c, mid); @@ -1177,15 +1179,17 @@ RETRY_TRY_BLOCK: mrb_method_missing(mrb, mid, recv, args); } mid = missing; + if (n == CALL_MAXARGS-1) { + regs[a+1] = mrb_ary_new_from_values(mrb, n, regs+a+1); + n++; + } if (n == CALL_MAXARGS) { mrb_ary_unshift(mrb, regs[a+1], sym); } else { - value_move(regs+a+2, regs+a+1, ++n); + value_move(regs+a+2, regs+a+1, n+bidx); regs[a+1] = sym; - if (n == CALL_MAXARGS) { - regs[a+1] = mrb_ary_new_from_values(mrb, n, regs+a+1); - } + n++; } } @@ -1355,6 +1359,10 @@ RETRY_TRY_BLOCK: mrb_method_missing(mrb, mid, recv, args); } mid = missing; + if (n == CALL_MAXARGS-1) { + regs[a+1] = mrb_ary_new_from_values(mrb, n, regs+a+1); + n++; + } if (n == CALL_MAXARGS) { mrb_ary_unshift(mrb, regs[a+1], mrb_symbol_value(ci->mid)); } |
