From 1518976cc628ecd4e598d4f53271ee354b12f4d4 Mon Sep 17 00:00:00 2001 From: nobu Date: Wed, 7 Nov 2007 06:07:52 +0000 Subject: * enum.c (enum_each_with_index): make different arrays at each iteration. [ruby-dev:32181] git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@13833 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 5 +++++ enum.c | 19 ++++++------------- 2 files changed, 11 insertions(+), 13 deletions(-) diff --git a/ChangeLog b/ChangeLog index f18e7d779..3a9920f3a 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Wed Nov 7 15:07:51 2007 Nobuyoshi Nakada + + * enum.c (enum_each_with_index): make different arrays at each + iteration. [ruby-dev:32181] + Tue Nov 7 05:17:24 2007 David Flanagan * eval.c: fix typo in invoke_method documentation diff --git a/enum.c b/enum.c index 5beb900d4..096772dd2 100644 --- a/enum.c +++ b/enum.c @@ -1293,15 +1293,9 @@ enum_member(VALUE obj, VALUE val) static VALUE each_with_index_i(VALUE val, VALUE memo) { - long n; - VALUE idx = RARRAY_PTR(memo)[1]; - - RARRAY_PTR(memo)[0] = val; - rb_yield(memo); - n = NUM2LONG(idx); - n++; - RARRAY_PTR(memo)[1] = INT2NUM(n); - return Qnil; + long n = (*(VALUE *)memo)++; + + return rb_yield(rb_ary_new3(2, val, INT2NUM(n))); } /* @@ -1322,12 +1316,12 @@ each_with_index_i(VALUE val, VALUE memo) static VALUE enum_each_with_index(int argc, VALUE *argv, VALUE obj) { - VALUE memo; + long memo; RETURN_ENUMERATOR(obj, argc, argv); - memo = rb_ary_new3(2, Qnil, INT2FIX(0)); - rb_block_call(obj, id_each, argc, argv, each_with_index_i, memo); + memo = 0; + rb_block_call(obj, id_each, argc, argv, each_with_index_i, (VALUE)&memo); return obj; } @@ -1534,7 +1528,6 @@ enum_drop_while(VALUE obj) return args[0]; } - static VALUE cycle_i(VALUE i, VALUE ary) { -- cgit