diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2017-04-05 22:28:46 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2017-04-05 22:30:39 +0900 |
| commit | a7b0ab3769d9f7f13d47c2c6f23298c87b88eee8 (patch) | |
| tree | 70dfecde64dd5050aa65834c3f99d75e262581ae /src | |
| parent | d9fb8b69b0621e8cd2c7c43fd8511a83718d7e45 (diff) | |
| download | mruby-a7b0ab3769d9f7f13d47c2c6f23298c87b88eee8.tar.gz mruby-a7b0ab3769d9f7f13d47c2c6f23298c87b88eee8.zip | |
Save block argument position in e->cioff; fix #3593
Diffstat (limited to 'src')
| -rw-r--r-- | src/kernel.c | 10 | ||||
| -rw-r--r-- | src/vm.c | 5 |
2 files changed, 13 insertions, 2 deletions
diff --git a/src/kernel.c b/src/kernel.c index 8670e0651..5ac0a3774 100644 --- a/src/kernel.c +++ b/src/kernel.c @@ -157,8 +157,14 @@ mrb_f_block_given_p_m(mrb_state *mrb, mrb_value self) /* top-level does not have block slot (alway false) */ if (sp == mrb->c->stbase) return mrb_false_value(); - ci = mrb->c->cibase + e->cioff; - bp = ci[1].stackent + 1; + if (e->cioff < 0) { + /* use saved block arg position */ + bp = &e->stack[-e->cioff]; + } + else { + ci = mrb->c->cibase + e->cioff; + bp = ci[1].stackent + 1; + } } } if (ci->argc > 0) { @@ -257,8 +257,13 @@ mrb_env_unshare(mrb_state *mrb, struct REnv *e) { size_t len = (size_t)MRB_ENV_STACK_LEN(e); mrb_value *p = (mrb_value *)mrb_malloc(mrb, sizeof(mrb_value)*len); + ptrdiff_t cioff = e->cioff; MRB_ENV_UNSHARE_STACK(e); + if (!e->c) { + /* save block argument position (negated) */ + e->cioff = -mrb->c->cibase[cioff].argc-1; + } if (len > 0) { stack_copy(p, e->stack, len); } |
