diff --git a/ChangeLog b/ChangeLog index 696c42713d..fb708da334 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,9 @@ +Thu Jul 31 15:25:12 2003 NAKAMURA Usaku + + * array.c (rb_ary_collect): must get length of array for each + iteration. reported on [ruby-talk:77500], and fixed by + K.Sasada on [ruby-talk:77504] + Thu Jul 31 14:11:54 2003 GOTOU Yuuzou * ext/openssl/extconf.rb: move gmake specific features diff --git a/array.c b/array.c index 9404e6ae5f..e51b8b54f4 100644 --- a/array.c +++ b/array.c @@ -1190,16 +1190,15 @@ static VALUE rb_ary_collect(ary) VALUE ary; { - long len, i; + long i; VALUE collect; if (!rb_block_given_p()) { return rb_ary_new4(RARRAY(ary)->len, RARRAY(ary)->ptr); } - len = RARRAY(ary)->len; - collect = rb_ary_new2(len); - for (i=0; ilen); + for (i = 0; i < RARRAY(ary)->len; i++) { rb_ary_push(collect, rb_yield(RARRAY(ary)->ptr[i])); } return collect;