diff options
author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2003-07-24 05:18:47 +0000 |
---|---|---|
committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2003-07-24 05:18:47 +0000 |
commit | e02b469de182c1d87ead38fa82630eaaee75c379 (patch) | |
tree | 425980c3ebfb78d38067b3b01f2df97a9dc0853d /gc.c | |
parent | 169300a4f8f6c704d9ef1dbed0b73f2dd7efdb68 (diff) |
* eval.c (thgroup_add): no warning for terminated threads.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@4142 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'gc.c')
-rw-r--r-- | gc.c | 12 |
1 files changed, 9 insertions, 3 deletions
@@ -1536,20 +1536,26 @@ run_final(obj) int status, critical_save; VALUE args[2], table; - critical_save = rb_thread_critical; - rb_thread_critical = Qtrue; args[1] = rb_ary_new3(1, rb_obj_id(obj)); /* make obj into id */ for (i=0; i<RARRAY(finalizers)->len; i++) { args[0] = RARRAY(finalizers)->ptr[i]; + critical_save = rb_thread_critical; + rb_thread_critical = Qtrue; rb_protect((VALUE(*)_((VALUE)))run_single_final, (VALUE)args, &status); + rb_thread_critical = critical_save; + CHECK_INTS; } + CHECK_INTS; if (finalizer_table && st_delete(finalizer_table, &obj, &table)) { for (i=0; i<RARRAY(table)->len; i++) { args[0] = RARRAY(table)->ptr[i]; + critical_save = rb_thread_critical; + rb_thread_critical = Qtrue; rb_protect((VALUE(*)_((VALUE)))run_single_final, (VALUE)args, &status); + rb_thread_critical = critical_save; + CHECK_INTS; } } - rb_thread_critical = critical_save; } void |