From 19451891d8750a44097fae76422642bd288e9197 Mon Sep 17 00:00:00 2001 From: nobu Date: Fri, 16 Mar 2012 08:33:10 +0000 Subject: * enum.c (enum_take): allocate buffer array before iteration, as well as enum_first did. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@35060 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 5 ++++- enum.c | 2 +- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/ChangeLog b/ChangeLog index c0469d7828..4654a93e11 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,4 +1,7 @@ -Fri Mar 16 15:02:35 2012 Nobuyoshi Nakada +Fri Mar 16 17:33:08 2012 Nobuyoshi Nakada + + * enum.c (enum_take): allocate buffer array before iteration, as well + as enum_first did. * enum.c (enum_first): remove duplication. diff --git a/enum.c b/enum.c index 1be1deab1a..fd5ba1cd48 100644 --- a/enum.c +++ b/enum.c @@ -2050,7 +2050,7 @@ enum_take(VALUE obj, VALUE n) } if (len == 0) return rb_ary_new2(0); - result = rb_ary_new(); + result = rb_ary_new2(len); memo = NEW_MEMO(result, 0, len); rb_block_call(obj, id_each, 0, 0, take_i, (VALUE)memo); return result; -- cgit v1.2.3