From fcb05d868316ebee7750537dea40e9de584aabf3 Mon Sep 17 00:00:00 2001 From: nagachika Date: Mon, 9 Jan 2012 15:35:06 +0000 Subject: [PATCH] * gc.c (run_finalizer): clear rb_thread_t::errinfo when ignore an exception under rb_protect(). [ruby-dev:45113] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@34250 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 5 +++++ gc.c | 3 +++ 2 files changed, 8 insertions(+) diff --git a/ChangeLog b/ChangeLog index 8b118ecd4f..b6e5d64413 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Tue Jan 10 00:32:17 2012 CHIKANAGA Tomoyuki + + * gc.c (run_finalizer): clear rb_thread_t::errinfo when ignore + an exception under rb_protect(). [ruby-dev:45113] + Mon Jan 9 23:37:43 2012 CHIKANAGA Tomoyuki * ext/readline/readline.c (readline_attempted_completion_function): diff --git a/gc.c b/gc.c index 67415b78e5..e6a7fcc330 100644 --- a/gc.c +++ b/gc.c @@ -3092,7 +3092,10 @@ run_finalizer(rb_objspace_t *objspace, VALUE obj, VALUE table) VALUE final = RARRAY_PTR(table)[i]; args[0] = RARRAY_PTR(final)[1]; args[2] = FIX2INT(RARRAY_PTR(final)[0]); + status = 0; rb_protect(run_single_final, (VALUE)args, &status); + if (status) + rb_set_errinfo(Qnil); } }