diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2015-02-26 14:40:02 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2015-02-26 14:40:02 +0900 |
| commit | a1d4992187146f99cc81045e6757f2b146f49193 (patch) | |
| tree | f51afb13aa5ecc4831f67a9d07a32df32d68eb3c | |
| parent | a2a272ca8ebecdc037b352ee95492accfeab9457 (diff) | |
| parent | 3fefe52ffb7286d129167c092d7ccc2908c37292 (diff) | |
| download | mruby-a1d4992187146f99cc81045e6757f2b146f49193.tar.gz mruby-a1d4992187146f99cc81045e6757f2b146f49193.zip | |
Merge pull request #2732 from kou/fix-a-crash-bug-on-raise-after-realloc
Fix a crash bug on raising after realloc
| -rw-r--r-- | src/vm.c | 4 |
1 files changed, 2 insertions, 2 deletions
@@ -316,7 +316,7 @@ mrb_funcall_with_block(mrb_state *mrb, mrb_value self, mrb_sym mid, mrb_int argc if (!mrb->jmp) { struct mrb_jmpbuf c_jmp; - mrb_callinfo *old_ci = mrb->c->ci; + size_t nth_ci = mrb->c->ci - mrb->c->cibase; MRB_TRY(&c_jmp) { mrb->jmp = &c_jmp; @@ -325,7 +325,7 @@ mrb_funcall_with_block(mrb_state *mrb, mrb_value self, mrb_sym mid, mrb_int argc mrb->jmp = 0; } MRB_CATCH(&c_jmp) { /* error */ - while (old_ci != mrb->c->ci) { + while (nth_ci < (mrb->c->ci - mrb->c->cibase)) { mrb->c->stack = mrb->c->ci->stackent; cipop(mrb); } |
