summaryrefslogtreecommitdiff
path: root/gc.c
diff options
context:
space:
mode:
authorko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-12-10 06:47:15 +0000
committerko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2013-12-10 06:47:15 +0000
commit1b29c00f00e42ade9858142b512b6eab211fb223 (patch)
tree1edede9d169f5cf0c44fcfba5489ca6041061f9e /gc.c
parent14979f2161e2d2f799f2b8b351d1cb451d13416b (diff)
* gc.c (allrefs_add): push obj only if allrefs table doesn't have
obj. * gc.c (allrefs_roots_i): ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@44113 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'gc.c')
-rw-r--r--gc.c11
1 files changed, 8 insertions, 3 deletions
diff --git a/gc.c b/gc.c
index 70df3309c1..53af182034 100644
--- a/gc.c
+++ b/gc.c
@@ -4231,7 +4231,8 @@ allrefs_add(struct allrefs *data, VALUE obj)
struct reflist *refs;
if (st_lookup(data->references, obj, (st_data_t *)&refs)) {
- return reflist_add(refs, data->root_obj);
+ reflist_add(refs, data->root_obj);
+ return 0;
}
else {
refs = reflist_create(data->root_obj);
@@ -4244,9 +4245,11 @@ static void
allrefs_i(VALUE obj, void *ptr)
{
struct allrefs *data = (struct allrefs *)ptr;
- if (allrefs_add(data, obj)) /* follow new reference */
+
+ if (allrefs_add(data, obj)) {
push_mark_stack(&data->objspace->mark_stack, obj);
}
+}
static void
allrefs_roots_i(VALUE obj, void *ptr)
@@ -4254,9 +4257,11 @@ allrefs_roots_i(VALUE obj, void *ptr)
struct allrefs *data = (struct allrefs *)ptr;
if (strlen(data->category) == 0) rb_bug("!!!");
data->root_obj = MAKE_ROOTSIG(data->category);
- allrefs_add(data, obj);
+
+ if (allrefs_add(data, obj)) {
push_mark_stack(&data->objspace->mark_stack, obj);
}
+}
static st_table *
objspace_allrefs(rb_objspace_t *objspace)