From 1448b0abf5247a4e4eec07a65aafa13d347a016a Mon Sep 17 00:00:00 2001 From: ko1 Date: Sun, 15 Dec 2013 04:42:23 +0000 Subject: * ext/objspace/objspace.c (reachable_object_from_root_i): reachable objects should not include categories and category_objects because it is noisy information. In fact, objects created after calling ObjectSpace.reachable_objects_from_root should not be included as a returning hash objects. Currently, mswin64 platform has a problem because of this behaviour. Should we trace new objects? git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@44222 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 11 +++++++++++ ext/objspace/objspace.c | 4 +++- 2 files changed, 14 insertions(+), 1 deletion(-) diff --git a/ChangeLog b/ChangeLog index c37db365ad..3d46abd1cc 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,14 @@ +Sun Dec 15 13:38:29 2013 Koichi Sasada + + * ext/objspace/objspace.c (reachable_object_from_root_i): + reachable objects should not include categories and + category_objects because it is noisy information. + + In fact, objects created after calling + ObjectSpace.reachable_objects_from_root should not be included + as a returning hash objects. Currently, mswin64 platform has a + problem because of this behaviour. Should we trace new objects? + Sun Dec 15 07:09:28 2013 Eric Hodel * lib/rdoc: Update to RDoc master 263a9e5. This improves the diff --git a/ext/objspace/objspace.c b/ext/objspace/objspace.c index 6dce515bf6..bddc1ceed1 100644 --- a/ext/objspace/objspace.c +++ b/ext/objspace/objspace.c @@ -679,7 +679,9 @@ reachable_object_from_root_i(const char *category, VALUE obj, void *ptr) rb_hash_aset(data->categories, category_str, category_objects); } - if (rb_objspace_markable_object_p(obj)) { + if (rb_objspace_markable_object_p(obj) && + obj != data->categories && + obj != data->last_category_objects) { if (rb_objspace_internal_object_p(obj)) { obj = iow_newobj(obj); } -- cgit v1.2.3