Counter.php 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. <?php
  2. /**
  3. * Hoa
  4. *
  5. *
  6. * @license
  7. *
  8. * New BSD License
  9. *
  10. * Copyright © 2007-2017, Hoa community. All rights reserved.
  11. *
  12. * Redistribution and use in source and binary forms, with or without
  13. * modification, are permitted provided that the following conditions are met:
  14. * * Redistributions of source code must retain the above copyright
  15. * notice, this list of conditions and the following disclaimer.
  16. * * Redistributions in binary form must reproduce the above copyright
  17. * notice, this list of conditions and the following disclaimer in the
  18. * documentation and/or other materials provided with the distribution.
  19. * * Neither the name of the Hoa nor the names of its contributors may be
  20. * used to endorse or promote products derived from this software without
  21. * specific prior written permission.
  22. *
  23. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  24. * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  25. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  26. * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS AND CONTRIBUTORS BE
  27. * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
  28. * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
  29. * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
  30. * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
  31. * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  32. * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  33. * POSSIBILITY OF SUCH DAMAGE.
  34. */
  35. namespace Hoa\Iterator;
  36. /**
  37. * Class \Hoa\Iterator\Counter.
  38. *
  39. * A counter.
  40. *
  41. * @copyright Copyright © 2007-2017 Hoa community
  42. * @license New BSD License
  43. */
  44. class Counter implements Iterator
  45. {
  46. /**
  47. * From (lower bound).
  48. *
  49. * @var int
  50. */
  51. protected $_from = 0;
  52. /**
  53. * Current key.
  54. *
  55. * @var int
  56. */
  57. protected $_key = 0;
  58. /**
  59. * Current index.
  60. *
  61. * @var int
  62. */
  63. protected $_i = 0;
  64. /**
  65. * To (upper bound).
  66. *
  67. * @var int
  68. */
  69. protected $_to = 0;
  70. /**
  71. * Step.
  72. *
  73. * @var int
  74. */
  75. protected $_step = 0;
  76. /**
  77. * Constructor.
  78. * Equivalent to:
  79. * for($i = $from; $i < $to; $i += $step)
  80. *
  81. * @param int $from Start value.
  82. * @param int $to Maximum value.
  83. * @param int $step Step.
  84. * @throws \Hoa\Iterator\Exception
  85. */
  86. public function __construct($from, $to, $step)
  87. {
  88. if ($step <= 0) {
  89. throw new Exception(
  90. 'The step must be non-negative; given %d.',
  91. 0,
  92. $step
  93. );
  94. }
  95. $this->_from = $from;
  96. $this->_to = $to;
  97. $this->_step = $step;
  98. return;
  99. }
  100. /**
  101. * Return the current element.
  102. *
  103. * @return int
  104. */
  105. public function current()
  106. {
  107. return $this->_i;
  108. }
  109. /**
  110. * Return the key of the current element.
  111. *
  112. * @return int
  113. */
  114. public function key()
  115. {
  116. return $this->_key;
  117. }
  118. /**
  119. * Move forward to next element.
  120. *
  121. * @return void
  122. */
  123. public function next()
  124. {
  125. ++$this->_key;
  126. $this->_i += $this->_step;
  127. return;
  128. }
  129. /**
  130. * Rewind the iterator to the first element.
  131. *
  132. * @return void
  133. */
  134. public function rewind()
  135. {
  136. $this->_key = 0;
  137. $this->_i = $this->_from;
  138. return;
  139. }
  140. /**
  141. * Check if current position is valid.
  142. *
  143. * @return bool
  144. */
  145. public function valid()
  146. {
  147. return $this->_i < $this->_to;
  148. }
  149. }