ruby-changes:2342
From: ko1@a...
Date: 7 Nov 2007 15:08:34 +0900
Subject: [ruby-changes:2342] nobu - Ruby:r13833 (trunk): * enum.c (enum_each_with_index): make different arrays at each
nobu 2007-11-07 15:07:52 +0900 (Wed, 07 Nov 2007)
New Revision: 13833
Modified files:
trunk/ChangeLog
trunk/enum.c
Log:
* enum.c (enum_each_with_index): make different arrays at each
iteration. [ruby-dev:32181]
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=13833&r2=13832
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/enum.c?r1=13833&r2=13832
Index: ChangeLog
===================================================================
--- ChangeLog (revision 13832)
+++ ChangeLog (revision 13833)
@@ -1,3 +1,8 @@
+Wed Nov 7 15:07:51 2007 Nobuyoshi Nakada <nobu@r...>
+
+ * enum.c (enum_each_with_index): make different arrays at each
+ iteration. [ruby-dev:32181]
+
Tue Nov 7 05:17:24 2007 David Flanagan <davidflanagan@r...>
* eval.c: fix typo in invoke_method documentation
Index: enum.c
===================================================================
--- enum.c (revision 13832)
+++ enum.c (revision 13833)
@@ -1293,15 +1293,9 @@
static VALUE
each_with_index_i(VALUE val, VALUE memo)
{
- long n;
- VALUE idx = RARRAY_PTR(memo)[1];
+ long n = (*(VALUE *)memo)++;
- RARRAY_PTR(memo)[0] = val;
- rb_yield(memo);
- n = NUM2LONG(idx);
- n++;
- RARRAY_PTR(memo)[1] = INT2NUM(n);
- return Qnil;
+ return rb_yield(rb_ary_new3(2, val, INT2NUM(n)));
}
/*
@@ -1322,12 +1316,12 @@
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 @@
return args[0];
}
-
static VALUE
cycle_i(VALUE i, VALUE ary)
{
--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml