From 358dd61107b64ca65cb6febb89f818388f62878e Mon Sep 17 00:00:00 2001 From: "Yukihiro \"Matz\" Matsumoto" Date: Fri, 19 Dec 2014 19:05:27 +0900 Subject: block_given? should return correct value when called in blocks; close #2678 avoid a loop to find parent's callinfo using mrb->c->cibase[env->cioff] --- src/kernel.c | 8 ++------ 1 file changed, 2 insertions(+), 6 deletions(-) (limited to 'src/kernel.c') diff --git a/src/kernel.c b/src/kernel.c index b6abfd265..485485da5 100644 --- a/src/kernel.c +++ b/src/kernel.c @@ -192,12 +192,8 @@ 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(); - while (mrb->c->cibase < ci) { - if (ci->stackent == sp) { - break; - } - ci--; - } + ci = mrb->c->cibase + ci->proc->env->cioff; + bp = ci[1].stackent + 1; } if (ci->argc > 0) { bp += ci->argc; -- cgit v1.2.3