From ee9cc4fc5287b873167d0d46f0ca123f049a95f7 Mon Sep 17 00:00:00 2001 From: yugui Date: Wed, 28 Jan 2009 09:21:18 +0000 Subject: 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 --- ChangeLog | 2 ++ gc.c | 4 +++- 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/ChangeLog b/ChangeLog index aee1dd95c..191b16bd2 100644 --- a/ChangeLog +++ b/ChangeLog @@ -3,6 +3,8 @@ Thu Jan 22 12:19:29 2009 Nobuyoshi Nakada * gc.c (define_final): cannot define finalizer for immediate values. [ruby-core:21500] + * gc.c (define_final): freezes or hides internal values. + Thu Jan 22 11:33:08 2009 Nobuyoshi Nakada * thread.c (rb_time_timeval): made a real prototype. a patch from 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; } -- cgit