diff options
author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2000-07-04 04:17:26 +0000 |
---|---|---|
committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2000-07-04 04:17:26 +0000 |
commit | 4f51d814183316c3e97da1dc13cf6945b5a76f2f (patch) | |
tree | 3ab2686a359f6cbdda8446d7382f9aa541c2490a /eval.c | |
parent | 5a8bfc39f132708bcf3ee2970e9f55ee6d101b65 (diff) |
matz
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@810 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'eval.c')
-rw-r--r-- | eval.c | 14 |
1 files changed, 11 insertions, 3 deletions
@@ -3679,9 +3679,9 @@ handle_rescue(self, node) } VALUE -rb_rescue(b_proc, data1, r_proc, data2) +rb_rescue2(b_proc, data1, eclass, r_proc, data2) VALUE (*b_proc)(), (*r_proc)(); - VALUE data1, data2; + VALUE data1, eclass, data2; { int state; volatile VALUE result; @@ -3692,7 +3692,7 @@ rb_rescue(b_proc, data1, r_proc, data2) retry_entry: result = (*b_proc)(data1); } - else if (state == TAG_RAISE && rb_obj_is_kind_of(ruby_errinfo, rb_eStandardError)) { + else if (state == TAG_RAISE && rb_obj_is_kind_of(ruby_errinfo, eclass)) { if (r_proc) { PUSH_TAG(PROT_NONE); if ((state = EXEC_TAG()) == 0) { @@ -3719,6 +3719,14 @@ rb_rescue(b_proc, data1, r_proc, data2) } VALUE +rb_rescue(b_proc, data1, r_proc, data2) + VALUE (*b_proc)(), (*r_proc)(); + VALUE data1, data2; +{ + return rb_rescue2(b_proc, data1, rb_eStandardError, r_proc, data2); +} + +VALUE rb_protect(proc, data, state) VALUE (*proc)(); VALUE data; |