summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2017-02-08 21:13:22 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2017-02-08 21:13:22 +0900
commitaf4d74fc7df9788a1c0013a4dc66e9bbac951b20 (patch)
tree74d979f399fd69182c60946ff19d1e225a3744e9
parent76135e757f96ad640e3c44b4d46f73e512fbfc50 (diff)
downloadmruby-af4d74fc7df9788a1c0013a4dc66e9bbac951b20.tar.gz
mruby-af4d74fc7df9788a1c0013a4dc66e9bbac951b20.zip
Add MRB_TT_PROC check to OP_SUPER as well; fix #3432
-rw-r--r--src/vm.c21
1 files changed, 16 insertions, 5 deletions
diff --git a/src/vm.c b/src/vm.c
index 287b18518..e734775e2 100644
--- a/src/vm.c
+++ b/src/vm.c
@@ -1366,11 +1366,22 @@ RETRY_TRY_BLOCK:
ci->mid = mid;
ci->proc = m;
ci->stackent = mrb->c->stack;
- if (n == CALL_MAXARGS) {
- ci->argc = -1;
- }
- else {
- ci->argc = n;
+ {
+ int bidx;
+ mrb_value blk;
+
+ if (n == CALL_MAXARGS) {
+ ci->argc = -1;
+ bidx = a+2;
+ }
+ else {
+ ci->argc = n;
+ bidx = a+n+1;
+ }
+ 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");
+ }
}
ci->target_class = c;
ci->pc = pc + 1;