wmde/traversable-iterator

Name: traversable-iterator

Owner: Wikimedia Deutschland e.V.

Description: Turn Traversable objects into Iterators. Fixed version of the native IteratorIterator

Created: 2017-06-17 16:50:47.0

Updated: 2017-06-17 17:17:21.0

Pushed: 2018-02-03 08:52:10.0

Homepage: null

Size: 16

Language: PHP

GitHub Committers

UserMost Recent Commit# Commits

Other Committers

UserEmailMost Recent Commit# Commits

README

Traversable Iterator

Build Status Scrutinizer Code Quality Code Coverage Latest Stable Version Download count

Iterator that can be constructed from Traversable objects.

Can be seen as a fixed version of IteratorIterator (which is used internally). IteratorIterator behaves in unexpected ways when constructed from an IteratorAggregate: it only calls getIterator once rather than once per iteration, which is what happens when you traverse the IteratorAggregate directly. In other words: looping over an IteratorIterator that contains a IteratorAggregate yields different behaviour than looping over the IteratorAggregate itself. This is unexpected and can be problematic. For instance when the IteratorAggregate contains a Generator (which happens often), looping over the IteratorIterator more than once will cause an error due to the Generator not being rewindable.

Example of how IteratorIterator fails:

ratorAggregate = new class() implements \IteratorAggregate {
public function getIterator() {
    yield 'a';
    yield 'b';
    yield 'c';
}


rator = new IteratorIterator( $iteratorAggregate );

ach ( $iterator as $value ) {}
ach ( $iterator as $value ) {} // Exception: Cannot rewind a generator that was already run

This exception, and more generally difference in behaviour, does not occur when using TraversableIterator.

Installation

To add this package as a local, per-project dependency to your project, simply add a dependency on wmde/traversable-iterator to your project's composer.json file. Here is a minimal example of a composer.json file that just defines a dependency on Traversable Iterator 1.x:


"require": {
    "wmde/traversable-iterator": "~1.0"
}

Usage
Running the tests

For a full CI run

composer ci

For tests only

composer test

For style checks only

composer cs
Release notes
1.0.0 (2017-06-17)

This work is supported by the National Institutes of Health's National Center for Advancing Translational Sciences, Grant Number U24TR002306. This work is solely the responsibility of the creators and does not necessarily represent the official views of the National Institutes of Health.