summaryrefslogtreecommitdiffstats
path: root/vm.c
diff options
context:
space:
mode:
authoryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-10-25 14:46:36 +0000
committeryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-10-25 14:46:36 +0000
commit51d5fb54472dcfa3b74a9420e5393544103f5116 (patch)
tree16868615fbbb66d0a1c9a51be19281a7f6e4a982 /vm.c
parent33b5b4da890ca17ef45f94edaf5610363e57ad2c (diff)
merges r24530 from trunk into ruby_1_9_1.
-- * vm.c (vm_exec): returning from lambda runs ensure section. [Bug #1729] git-svn-id: http://svn.ruby-lang.org/repos/ruby/branches/ruby_1_9_1@25480 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'vm.c')
-rw-r--r--vm.c21
1 files changed, 17 insertions, 4 deletions
diff --git a/vm.c b/vm.c
index c39048b49..3efab55f8 100644
--- a/vm.c
+++ b/vm.c
@@ -1114,10 +1114,23 @@ vm_exec(rb_thread_t *th)
SET_THROWOBJ_STATE(err, state = TAG_BREAK);
}
else {
- result = GET_THROWOBJ_VAL(err);
- th->errinfo = Qnil;
- th->cfp += 2;
- goto finish_vme;
+ for (i = 0; i < cfp->iseq->catch_table_size; i++) {
+ entry = &cfp->iseq->catch_table[i];
+ if (entry->start < epc && entry->end >= epc) {
+ if (entry->type == CATCH_TYPE_ENSURE) {
+ catch_iseqval = entry->iseq;
+ cont_pc = entry->cont;
+ cont_sp = entry->sp;
+ break;
+ }
+ }
+ }
+ if (!catch_iseqval) {
+ result = GET_THROWOBJ_VAL(err);
+ th->errinfo = Qnil;
+ th->cfp += 2;
+ goto finish_vme;
+ }
}
/* through */
}