summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2017-04-05 22:28:46 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2017-04-05 22:30:39 +0900
commita7b0ab3769d9f7f13d47c2c6f23298c87b88eee8 (patch)
tree70dfecde64dd5050aa65834c3f99d75e262581ae /src
parentd9fb8b69b0621e8cd2c7c43fd8511a83718d7e45 (diff)
downloadmruby-a7b0ab3769d9f7f13d47c2c6f23298c87b88eee8.tar.gz
mruby-a7b0ab3769d9f7f13d47c2c6f23298c87b88eee8.zip
Save block argument position in e->cioff; fix #3593
Diffstat (limited to 'src')
-rw-r--r--src/kernel.c10
-rw-r--r--src/vm.c5
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) {
diff --git a/src/vm.c b/src/vm.c
index 518323cf7..f67e73533 100644
--- a/src/vm.c
+++ b/src/vm.c
@@ -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);
}