From 75e7f2ff2d23c8a148558c71c88157635ba3fda3 Mon Sep 17 00:00:00 2001 From: nagachika Date: Sun, 12 Jan 2014 14:23:53 +0000 Subject: merge revision(s) 44260: [Backport #9168] patch inspired from r44260 on trunk. [ruby-core:58652] [Bug #9168] * gc.c (run_finalizer): clear th->errinfo before invoke finalizer and restore afterward. * test/ruby/test_gc.rb (test_exception_in_finalizer): add test for above. * vm_trace.c (rb_threadptr_exec_event_hooks_orig): clear th->errinfo before invoke hook. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_0_0@44576 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- gc.c | 3 +++ 1 file changed, 3 insertions(+) (limited to 'gc.c') diff --git a/gc.c b/gc.c index a654e2ec5c..71fd2ced8f 100644 --- a/gc.c +++ b/gc.c @@ -1375,6 +1375,7 @@ run_finalizer(rb_objspace_t *objspace, VALUE obj, VALUE table) int status; VALUE args[3]; VALUE objid = nonspecial_obj_id(obj); + VALUE saved_errinfo = rb_errinfo(); if (RARRAY_LEN(table) > 0) { args[1] = rb_obj_freeze(rb_ary_new3(1, objid)); @@ -1384,6 +1385,7 @@ run_finalizer(rb_objspace_t *objspace, VALUE obj, VALUE table) } args[2] = (VALUE)rb_safe_level(); + rb_set_errinfo(Qnil); for (i=0; ierrinfo = saved_errinfo; } static void -- cgit v1.2.3