diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2017-06-02 14:22:18 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2017-06-02 14:22:18 +0900 |
| commit | ab85d3c81478a88748ad76521ceab62115cc009d (patch) | |
| tree | bd2cc78a05dcda86f1a5e3b30b83c00f22516448 | |
| parent | 7f417ade42d19f931ff930ba118c5c4393c74ae9 (diff) | |
| download | mruby-ab85d3c81478a88748ad76521ceab62115cc009d.tar.gz mruby-ab85d3c81478a88748ad76521ceab62115cc009d.zip | |
Make `break` in lambdas work as `return` according to CRuby behavior.
| -rw-r--r-- | src/backtrace.c | 2 | ||||
| -rw-r--r-- | src/vm.c | 2 |
2 files changed, 3 insertions, 1 deletions
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; @@ -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; |
