2015-04-08 23:19:24 +02:00
..
2015-03-07 14:11:42 +08:00
2014-07-31 14:47:55 -05:00
2014-03-24 10:40:08 -03:00
2015-03-07 14:11:42 +08:00
2014-04-16 17:59:03 -03:00
2014-04-16 17:59:03 -03:00
2015-04-08 23:19:24 +02:00

`Iterator`_
===========

Purpose
-------

To make an object iterable and to make it appear like a collection of
objects.

Examples
--------

-  to process a file line by line by just running over all lines (which
   have an object representation) for a file (which of course is an
   object, too)

Note
----

Standard PHP Library (SPL) defines an interface Iterator which is best
suited for this! Often you would want to implement the Countable
interface too, to allow ``count($object)`` on your iterable object

UML Diagram
-----------

.. image:: uml/uml.png
   :alt: Alt Iterator UML Diagram
   :align: center

Code
----

You can also find these code on `GitHub`_

Book.php

.. literalinclude:: Book.php
   :language: php
   :linenos:

BookList.php

.. literalinclude:: BookList.php
   :language: php
   :linenos:

BookListIterator.php

.. literalinclude:: BookListIterator.php
   :language: php
   :linenos:

BookListReverseIterator.php

.. literalinclude:: BookListReverseIterator.php
   :language: php
   :linenos:

Test
----

Tests/IteratorTest.php

.. literalinclude:: Tests/IteratorTest.php
   :language: php
   :linenos:

.. _`GitHub`: https://github.com/domnikl/DesignPatternsPHP/tree/master/Behavioral/Iterator
.. _`Iterator`: http://en.wikipedia.org/wiki/Iterator_pattern