summaryrefslogtreecommitdiffstats
path: root/gc.c
diff options
context:
space:
mode:
authoryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-01-28 09:21:18 +0000
committeryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-01-28 09:21:18 +0000
commitee9cc4fc5287b873167d0d46f0ca123f049a95f7 (patch)
tree231d778a01824ce7287ffa7010a85b944ae1994c /gc.c
parent5d46c6fe91d00061322b80c69d3f39926b64a439 (diff)
merges the 2/2 of r21727 from trunk into ruby_1_9_1.
* gc.c (define_final): freezes or hides internal values. git-svn-id: http://svn.ruby-lang.org/repos/ruby/branches/ruby_1_9_1@21821 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'gc.c')
-rw-r--r--gc.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/gc.c b/gc.c
index 2d4da31a7..002abb3bc 100644
--- a/gc.c
+++ b/gc.c
@@ -2306,7 +2306,9 @@ define_final(int argc, VALUE *argv, VALUE os)
rb_ary_push(table, block);
}
else {
- st_add_direct(finalizer_table, obj, rb_ary_new3(1, block));
+ table = rb_ary_new3(1, block);
+ RBASIC(table)->klass = 0;
+ st_add_direct(finalizer_table, obj, table);
}
return block;
}