mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
bb3d794929
* ext/-test-/exception/ensured.c (exc_raise): get rid of conflict with raise(2) in the standard. [ruby-core:79371] [Bug #13176] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@57511 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
39 lines
697 B
C
39 lines
697 B
C
#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);
|
|
}
|
|
|
|
static VALUE
|
|
exc_raise(VALUE exc)
|
|
{
|
|
rb_exc_raise(exc);
|
|
return Qnil;
|
|
}
|
|
|
|
static VALUE
|
|
ensure_raise(VALUE module, VALUE object, VALUE exc)
|
|
{
|
|
return rb_ensure(rb_yield, object, exc_raise, exc);
|
|
}
|
|
|
|
void
|
|
Init_ensured(VALUE klass)
|
|
{
|
|
rb_define_module_function(klass, "ensured", ensured, 1);
|
|
rb_define_module_function(klass, "ensure_raise", ensure_raise, 2);
|
|
}
|