summaryrefslogtreecommitdiff
path: root/enum.c
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2005-07-14 15:15:22 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2005-07-14 15:15:22 +0000
commitd725e6666a76ec9d0f5fda7fc24262cb4b498c17 (patch)
treea1393f9e88e66ae7e9a4a7f7b41ef4a1b9670659 /enum.c
parentf1fbedf1a622710984dd9836947214f4ce169772 (diff)
* enum.c (enumeratorize): create new enumerator for current method if
no block is given. * enumerator.c: moved from ext/enumerator. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@8764 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'enum.c')
-rw-r--r--enum.c43
1 files changed, 36 insertions, 7 deletions
diff --git a/enum.c b/enum.c
index 3f9ae1d00a..2b572c85ba 100644
--- a/enum.c
+++ b/enum.c
@@ -17,6 +17,15 @@
VALUE rb_mEnumerable;
static ID id_each, id_eqq, id_cmp;
+static VALUE
+enumeratorize(argc, argv, obj)
+ int argc;
+ VALUE *argv;
+ VALUE obj;
+{
+ return rb_enumeratorize(obj, ID2SYM(rb_frame_this_func()), argc, argv);
+}
+
VALUE
rb_each(obj)
VALUE obj;
@@ -114,6 +123,8 @@ enum_find(argc, argv, obj)
VALUE if_none;
rb_scan_args(argc, argv, "01", &if_none);
+ if (!rb_block_given_p())
+ return enumeratorize(argc, argv, obj);
rb_iterate(rb_each, obj, find_i, (VALUE)&memo);
if (memo != Qundef) {
return memo;
@@ -151,8 +162,11 @@ static VALUE
enum_find_all(obj)
VALUE obj;
{
- VALUE ary = rb_ary_new();
+ VALUE ary;
+ if (!rb_block_given_p()) return enumeratorize(0, 0, obj);
+
+ ary = rb_ary_new();
rb_iterate(rb_each, obj, find_all_i, ary);
return ary;
@@ -183,8 +197,11 @@ static VALUE
enum_reject(obj)
VALUE obj;
{
- VALUE ary = rb_ary_new();
+ VALUE ary;
+ if (!rb_block_given_p()) return enumeratorize(0, 0, obj);
+
+ ary = rb_ary_new();
rb_iterate(rb_each, obj, reject_i, ary);
return ary;
@@ -225,9 +242,12 @@ static VALUE
enum_collect(obj)
VALUE obj;
{
- VALUE ary = rb_ary_new();
+ VALUE ary;
+
+ if (!rb_block_given_p()) return enumeratorize(0, 0, obj);
- rb_iterate(rb_each, obj, rb_block_given_p() ? collect_i : collect_all, ary);
+ ary = rb_ary_new();
+ rb_iterate(rb_each, obj, collect_i, ary);
return ary;
}
@@ -343,6 +363,8 @@ enum_partition(obj)
{
VALUE ary[2];
+ if (!rb_block_given_p()) return enumeratorize(0, 0, obj);
+
ary[0] = rb_ary_new();
ary[1] = rb_ary_new();
rb_iterate(rb_each, obj, partition_i, (VALUE)ary);
@@ -476,6 +498,8 @@ enum_sort_by(obj)
VALUE ary;
long i;
+ if (!rb_block_given_p()) return enumeratorize(0, 0, obj);
+
if (TYPE(obj) == T_ARRAY) {
ary = rb_ary_new2(RARRAY(obj)->len);
}
@@ -763,7 +787,8 @@ enum_min_by(obj)
{
VALUE memo[2];
- rb_need_block();
+ if (!rb_block_given_p()) return enumeratorize(0, 0, obj);
+
memo[0] = Qundef;
memo[1] = Qnil;
rb_iterate(rb_each, obj, min_by_i, (VALUE)memo);
@@ -806,7 +831,8 @@ enum_max_by(obj)
{
VALUE memo[2];
- rb_need_block();
+ if (!rb_block_given_p()) return enumeratorize(0, 0, obj);
+
memo[0] = Qundef;
memo[1] = Qnil;
rb_iterate(rb_each, obj, max_by_i, (VALUE)memo);
@@ -844,6 +870,8 @@ enum_member(obj, val)
{
VALUE memo[2];
+ if (!rb_block_given_p()) return enumeratorize(1, &val, obj);
+
memo[0] = val;
memo[1] = Qfalse;
rb_iterate(rb_each, obj, member_i, (VALUE)memo);
@@ -881,7 +909,8 @@ enum_each_with_index(obj)
{
VALUE memo = 0;
- rb_need_block();
+ if (!rb_block_given_p()) return enumeratorize(0, 0, obj);
+
rb_iterate(rb_each, obj, each_with_index_i, (VALUE)&memo);
return obj;
}