diff options
author | yugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-01-28 09:21:18 +0000 |
---|---|---|
committer | yugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-01-28 09:21:18 +0000 |
commit | 4d70e4a70674b1c7894fef725927afd5a129f064 (patch) | |
tree | 231d778a01824ce7287ffa7010a85b944ae1994c /gc.c | |
parent | 508874c8af7ce2f0a8708256e166b001f62870e1 (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: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_9_1@21821 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'gc.c')
-rw-r--r-- | gc.c | 4 |
1 files changed, 3 insertions, 1 deletions
@@ -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; } |