summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
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);
}