summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog5
-rw-r--r--enum.c24
2 files changed, 17 insertions, 12 deletions
diff --git a/ChangeLog b/ChangeLog
index e99789ebcd..63b5251d6d 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Thu Jun 25 06:25:49 2009 Yukihiro Matsumoto <matz@ruby-lang.org>
+
+ * enum.c (first_i): wrong condition for no argument #first.
+ [ruby-core:24017]
+
Wed Jun 24 20:19:11 2009 Tanaka Akira <akr@fsij.org>
* time.c (time_s_now): new function. Time.now don't take arguments.
diff --git a/enum.c b/enum.c
index 720fc09e41..e63d04af4f 100644
--- a/enum.c
+++ b/enum.c
@@ -608,23 +608,23 @@ enum_group_by(VALUE obj)
}
static VALUE
-first_i(VALUE i, VALUE *ary, int argc, VALUE *argv)
+first_i(VALUE i, VALUE *params, int argc, VALUE *argv)
{
ENUM_WANT_SVALUE();
- if (NIL_P(ary[0])) {
- ary[1] = i;
+ if (NIL_P(params[1])) {
+ params[1] = i;
rb_iter_break();
}
else {
- long n = ary[0];
+ long n = params[0];
- rb_ary_push(ary[1], i);
+ rb_ary_push(params[1], i);
n--;
if (n <= 0) {
rb_iter_break();
}
- ary[0] = n;
+ params[0] = n;
}
return Qnil;
}
@@ -643,10 +643,10 @@ first_i(VALUE i, VALUE *ary, int argc, VALUE *argv)
static VALUE
enum_first(int argc, VALUE *argv, VALUE obj)
{
- VALUE n, ary[2];
+ VALUE n, params[2];
if (argc == 0) {
- ary[0] = ary[1] = Qnil;
+ params[0] = params[1] = Qnil;
}
else {
long len;
@@ -657,12 +657,12 @@ enum_first(int argc, VALUE *argv, VALUE obj)
if (len < 0) {
rb_raise(rb_eArgError, "negative length");
}
- ary[0] = len;
- ary[1] = rb_ary_new2(len);
+ params[0] = len;
+ params[1] = rb_ary_new2(len);
}
- rb_block_call(obj, id_each, 0, 0, first_i, (VALUE)ary);
+ rb_block_call(obj, id_each, 0, 0, first_i, (VALUE)params);
- return ary[1];
+ return params[1];
}