mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
eval.c: preserve errinfo
* eval.c (rb_ensure): preserve errinfo accross ensure proc before JUMP_TAG(). [ruby-core:52022] [Bug #7802] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@39156 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
49c5a3da6f
commit
98932f5150
4 changed files with 66 additions and 0 deletions
25
ext/-test-/exception/ensured.c
Normal file
25
ext/-test-/exception/ensured.c
Normal file
|
|
@ -0,0 +1,25 @@
|
|||
#include <ruby.h>
|
||||
|
||||
static VALUE
|
||||
begin(VALUE object)
|
||||
{
|
||||
return rb_funcall(object, rb_intern("try_method"), 0);
|
||||
}
|
||||
|
||||
static VALUE
|
||||
ensure(VALUE object)
|
||||
{
|
||||
return rb_funcall(object, rb_intern("ensured_method"), 0);
|
||||
}
|
||||
|
||||
static VALUE
|
||||
ensured(VALUE module, VALUE object)
|
||||
{
|
||||
return rb_ensure(begin, object, ensure, object);
|
||||
}
|
||||
|
||||
void
|
||||
Init_ensured(VALUE klass)
|
||||
{
|
||||
rb_define_module_function(klass, "ensured", ensured, 1);
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue