import std.stdio; import std.range; import std.algorithm; void main() { auto a = inputRangeObject(iota(3).filter!"true"); writeln(a.cycle.take(10)); } Outputs [0, 1, 2, 0, 1, 2, then asserts: http://dpaste.dzfl.pl/84de028d The problem is Cycle.popFront: void popFront() { _current.popFront(); if (_current.empty) _current = _original; } It should be _current = _original.save, otherwise the _original range is consumed on the second iteration.
(In reply to comment #0) > import std.stdio; > import std.range; > import std.algorithm; > > void main() > { > auto a = inputRangeObject(iota(3).filter!"true"); > writeln(a.cycle.take(10)); > } > > Outputs > > [0, 1, 2, 0, 1, 2, > > then asserts: http://dpaste.dzfl.pl/84de028d > > The problem is Cycle.popFront: > > void popFront() > { > _current.popFront(); > if (_current.empty) _current = _original; > } > > It should be _current = _original.save, otherwise the _original range is > consumed on the second iteration. I have an open pull for improving cycle: https://github.com/D-Programming-Language/phobos/pull/1149 So I integrated the fix in it. That said, given how often my pulls get reviewed and pulled, it might be best if you created a pull for this that _I_ could review and pull...
Commit pushed to master at https://github.com/D-Programming-Language/phobos https://github.com/D-Programming-Language/phobos/commit/25f123687cca76ba4a4db6408ba2231ced54030e Fix issue 10845