diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2016-10-20 23:49:40 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2016-10-20 23:49:40 +0900 |
| commit | 6fd0e601cf8b82e331710e6895dc3122cd7a5082 (patch) | |
| tree | b1e271e2218ea16af24a965e578b97421869c228 /src | |
| parent | 8488425e5038996783315945ad7e2c69e04cfb70 (diff) | |
| download | mruby-6fd0e601cf8b82e331710e6895dc3122cd7a5082.tar.gz mruby-6fd0e601cf8b82e331710e6895dc3122cd7a5082.zip | |
Move to_proc conversion from OP_ENTER to OP_SENDB; fix #3227
Diffstat (limited to 'src')
| -rw-r--r-- | src/vm.c | 21 |
1 files changed, 13 insertions, 8 deletions
@@ -1094,14 +1094,22 @@ RETRY_TRY_BLOCK: mrb_callinfo *ci; mrb_value recv, result; mrb_sym mid = syms[GETARG_B(i)]; + int bidx; recv = regs[a]; + if (n == CALL_MAXARGS) { + bidx = a+2; + } + else { + bidx = a+n+1; + } if (GET_OPCODE(i) != OP_SENDB) { - if (n == CALL_MAXARGS) { - SET_NIL_VALUE(regs[a+2]); - } - else { - SET_NIL_VALUE(regs[a+n+1]); + SET_NIL_VALUE(regs[bidx]); + } + 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"); } } c = mrb_class(mrb, recv); @@ -1420,9 +1428,6 @@ RETRY_TRY_BLOCK: int len = m1 + o + r + m2; mrb_value *blk = &argv[argc < 0 ? 1 : argc]; - if (!mrb_nil_p(*blk) && mrb_type(*blk) != MRB_TT_PROC) { - *blk = mrb_convert_type(mrb, *blk, MRB_TT_PROC, "Proc", "to_proc"); - } if (argc < 0) { struct RArray *ary = mrb_ary_ptr(regs[1]); argv = ary->ptr; |
