diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-10-01 12:36:38 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2008-10-01 12:36:38 +0000 |
commit | 952385b71267a843f8e71d0573f5b2fcf5709787 (patch) | |
tree | e8173a9fc10ae25357ba7c2c08c5505b2e98d3bb | |
parent | e5afadda03c70f4fe6b8228a0b2478ce9eed4e01 (diff) |
* gc.c (rb_gc_call_finalizer_at_exit): finalize deferred IO and Data.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@19656 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 4 | ||||
-rw-r--r-- | gc.c | 10 |
2 files changed, 11 insertions, 3 deletions
@@ -1,4 +1,6 @@ -Wed Oct 1 19:13:55 2008 Nobuyoshi Nakada <[email protected]> +Wed Oct 1 21:36:35 2008 Nobuyoshi Nakada <[email protected]> + + * gc.c (rb_gc_call_finalizer_at_exit): finalize deferred IO and Data. * gc.c (rb_gc_call_finalizer_at_exit): deffers IO finalization. [ruby-dev:36646] @@ -2357,13 +2357,13 @@ rb_gc_call_finalizer_at_exit(void) { rb_objspace_t *objspace = &rb_objspace; RVALUE *p, *pend; + RVALUE *final_list = 0; size_t i; /* run finalizers */ if (finalizer_table) { finalize_deferred(objspace); while (finalizer_table->num_entries > 0) { - RVALUE *final_list = 0; st_foreach(finalizer_table, chain_finalized_object, (st_data_t)&final_list); if (!(p = final_list)) break; @@ -2390,18 +2390,24 @@ rb_gc_call_finalizer_at_exit(void) } else if (RANY(p)->as.data.dfree) { make_deferred(RANY(p)); + RANY(p)->as.free.next = final_list; + final_list = p; } } else if (BUILTIN_TYPE(p) == T_FILE) { if (RANY(p)->as.file.fptr) { make_io_deferred(RANY(p)); + RANY(p)->as.free.next = final_list; + final_list = p; } } p++; } } during_gc = 0; - finalize_deferred(objspace); + if (final_list) { + finalize_list(objspace, final_list); + } } void |