[前][次][番号順一覧][スレッド一覧]

ruby-changes:7208

From: nobu <ko1@a...>
Date: Wed, 20 Aug 2008 22:25:17 +0900 (JST)
Subject: [ruby-changes:7208] Ruby:r18727 (trunk): * enum.c (enum_take): get rid of extraneous iteration.

nobu	2008-08-20 22:24:51 +0900 (Wed, 20 Aug 2008)

  New Revision: 18727

  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=18727

  Log:
    * enum.c (enum_take): get rid of extraneous iteration.

  Modified files:
    trunk/ChangeLog
    trunk/enum.c

Index: ChangeLog
===================================================================
--- ChangeLog	(revision 18726)
+++ ChangeLog	(revision 18727)
@@ -1,3 +1,7 @@
+Wed Aug 20 22:24:48 2008  Nobuyoshi Nakada  <nobu@r...>
+
+	* enum.c (enum_take): get rid of extraneous iteration.
+
 Wed Aug 20 20:32:49 2008  Tanaka Akira  <akr@f...>
 
 	* io.c (rb_io_open_with_args): use rb_open_file instead of rb_io_open.
Index: enum.c
===================================================================
--- enum.c	(revision 18726)
+++ enum.c	(revision 18727)
@@ -1585,8 +1585,8 @@
 static VALUE
 take_i(VALUE i, VALUE *arg, int argc, VALUE *argv)
 {
-    if (arg[1]-- == 0) rb_iter_break();
     rb_ary_push(arg[0], enum_values_pack(argc, argv));
+    if (--arg[1] == 0) rb_iter_break();
     return Qnil;
 }
 
@@ -1611,8 +1611,9 @@
 	rb_raise(rb_eArgError, "attempt to take negative size");
     }
 
+    if (len == 0) return rb_ary_new2(0);
+    args[0] = rb_ary_new();
     args[1] = len;
-    args[0] = rb_ary_new();
     rb_block_call(obj, id_each, 0, 0, take_i, (VALUE)args);
     return args[0];
 }

--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/

[前][次][番号順一覧][スレッド一覧]