summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2016-10-20 23:49:40 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2016-10-20 23:49:40 +0900
commit6fd0e601cf8b82e331710e6895dc3122cd7a5082 (patch)
treeb1e271e2218ea16af24a965e578b97421869c228 /src
parent8488425e5038996783315945ad7e2c69e04cfb70 (diff)
downloadmruby-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.c21
1 files changed, 13 insertions, 8 deletions
diff --git a/src/vm.c b/src/vm.c
index 832c6c3b2..01ae0326c 100644
--- a/src/vm.c
+++ b/src/vm.c
@@ -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;