summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authormarcandre <marcandre@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2012-11-06 17:16:58 +0000
committermarcandre <marcandre@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2012-11-06 17:16:58 +0000
commit0814c4ac643fcbb2d7f2d6c077fa1626a5e59b77 (patch)
tree7c831ae332ff0304fe3d086c5f235f04658ceeb2
parent7a31096255cd226d16c918fa859e3e4a654e64b9 (diff)
* enumerator.c: Support for lazy.cycle.size
[Feature #6636] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@37525 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--enum.c2
-rw-r--r--enumerator.c7
-rw-r--r--internal.h3
-rw-r--r--test/ruby/test_lazy_enumerator.rb9
4 files changed, 19 insertions, 2 deletions
diff --git a/enum.c b/enum.c
index e9c925611d..789a88b8ca 100644
--- a/enum.c
+++ b/enum.c
@@ -2235,7 +2235,7 @@ cycle_i(VALUE i, VALUE ary, int argc, VALUE *argv)
return Qnil;
}
-static VALUE
+VALUE
enum_cycle_size(VALUE self, VALUE args)
{
long mul;
diff --git a/enumerator.c b/enumerator.c
index 0a51709ac1..9223979445 100644
--- a/enumerator.c
+++ b/enumerator.c
@@ -1741,6 +1741,11 @@ lazy_drop_while(VALUE obj)
}
static VALUE
+lazy_cycle_size(VALUE lazy) {
+ return enum_cycle_size(rb_ivar_get(lazy, id_receiver), rb_ivar_get(lazy, id_arguments));
+}
+
+static VALUE
lazy_cycle_func(VALUE val, VALUE m, int argc, VALUE *argv)
{
return rb_funcall2(argv[0], id_yield, argc - 1, argv + 1);
@@ -1764,7 +1769,7 @@ lazy_cycle(int argc, VALUE *argv, VALUE obj)
return lazy_set_method(rb_block_call(rb_cLazy, id_new, len,
RARRAY_PTR(args), lazy_cycle_func,
args /* prevent from GC */),
- rb_ary_new4(argc, argv), 0);
+ rb_ary_new4(argc, argv), lazy_cycle_size);
}
static VALUE
diff --git a/internal.h b/internal.h
index 5b66192ddf..9bf66c2780 100644
--- a/internal.h
+++ b/internal.h
@@ -87,6 +87,9 @@ ID rb_id_encoding(void);
/* encoding.c */
void rb_gc_mark_encodings(void);
+/* enum.c */
+VALUE enum_cycle_size(VALUE self, VALUE args);
+
/* error.c */
NORETURN(PRINTF_ARGS(void rb_compile_bug(const char*, int, const char*, ...), 3, 4));
VALUE rb_check_backtrace(VALUE);
diff --git a/test/ruby/test_lazy_enumerator.rb b/test/ruby/test_lazy_enumerator.rb
index 9647590136..b34bb033d5 100644
--- a/test/ruby/test_lazy_enumerator.rb
+++ b/test/ruby/test_lazy_enumerator.rb
@@ -346,5 +346,14 @@ EOS
assert_equal 0, lazy.drop(4).size
assert_equal Float::INFINITY, loop.lazy.drop(4).size
assert_equal nil, lazy.select{}.drop(4).size
+
+ assert_equal 0, lazy.cycle(0).size
+ assert_equal 6, lazy.cycle(2).size
+ assert_equal 3 << 80, 4.times.inject(lazy){|enum| enum.cycle(1 << 20)}.size
+ assert_equal Float::INFINITY, lazy.cycle.size
+ assert_equal Float::INFINITY, loop.lazy.cycle(4).size
+ assert_equal Float::INFINITY, loop.lazy.cycle.size
+ assert_equal nil, lazy.select{}.cycle(4).size
+ assert_equal nil, lazy.select{}.cycle.size
end
end