From bf8168cf334e45ce6e93fa5aedc74ab7ca4069f3 Mon Sep 17 00:00:00 2001 From: nobu Date: Tue, 4 Oct 2011 06:04:46 +0000 Subject: [PATCH] * class.c (class_alloc): allocate extra memory after containing object setup to get rid of rare-but-potential memory leak. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@33397 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 5 +++++ class.c | 3 +-- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/ChangeLog b/ChangeLog index 544fef4aaa..60564af72d 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Tue Oct 4 15:04:43 2011 Nobuyoshi Nakada + + * class.c (class_alloc): allocate extra memory after containing + object setup to get rid of rare-but-potential memory leak. + Tue Oct 4 11:44:10 2011 NARUSE, Yui * gc.c (rb_gc_set_params): ruby_verbose can be Qnil, so use RTEST. diff --git a/class.c b/class.c index e6c1f8fd11..b595473333 100644 --- a/class.c +++ b/class.c @@ -49,10 +49,9 @@ static ID id_attached; static VALUE class_alloc(VALUE flags, VALUE klass) { - rb_classext_t *ext = ALLOC(rb_classext_t); NEWOBJ(obj, struct RClass); OBJSETUP(obj, klass, flags); - obj->ptr = ext; + obj->ptr = ALLOC(rb_classext_t); RCLASS_IV_TBL(obj) = 0; RCLASS_CONST_TBL(obj) = 0; RCLASS_M_TBL(obj) = 0;