From ab85d3c81478a88748ad76521ceab62115cc009d Mon Sep 17 00:00:00 2001 From: "Yukihiro \"Matz\" Matsumoto" Date: Fri, 2 Jun 2017 14:22:18 +0900 Subject: Make `break` in lambdas work as `return` according to CRuby behavior. --- src/backtrace.c | 2 +- src/vm.c | 2 ++ 2 files changed, 3 insertions(+), 1 deletion(-) (limited to 'src') diff --git a/src/backtrace.c b/src/backtrace.c index 392ce4e07..19a54b7e5 100644 --- a/src/backtrace.c +++ b/src/backtrace.c @@ -168,7 +168,7 @@ static mrb_value packed_backtrace(mrb_state *mrb) { struct RData *backtrace; - mrb_int ciidx = mrb->c->ci - mrb->c->cibase; + ptrdiff_t ciidx = mrb->c->ci - mrb->c->cibase; mrb_int len = (ciidx+1)*sizeof(struct backtrace_location); void *ptr; diff --git a/src/vm.c b/src/vm.c index 6070ecba1..b07624488 100644 --- a/src/vm.c +++ b/src/vm.c @@ -1841,6 +1841,7 @@ RETRY_TRY_BLOCK: break; } case OP_R_NORMAL: + NORMAL_RETURN: if (ci == mrb->c->cibase) { if (!mrb->c->prev) { /* toplevel return */ localjump_error(mrb, LOCALJUMP_ERROR_RETURN); @@ -1862,6 +1863,7 @@ RETRY_TRY_BLOCK: ci = mrb->c->ci; break; case OP_R_BREAK: + if (MRB_PROC_STRICT_P(proc)) goto NORMAL_RETURN; if (!proc->env || !MRB_ENV_STACK_SHARED_P(proc->env)) { mrb_value exc; -- cgit v1.2.3