-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathUserListIterator.php
77 lines (67 loc) · 1.63 KB
/
UserListIterator.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
<?php
namespace DesignPatterns\Behavioral\Iterator;
include_once 'UserList.php';
class UserListIterator implements \Iterator
{
/**
* @var UserList
*/
private $userList = [];
/**
* @var int
*/
private $key = 0;
/**
* @param UserList $list
*/
public function __construct(UserList $list)
{
$this->userList = $list;
}
/**
* Return the current element
* @link http://php.net/manual/en/iterator.current.php
* @return User
*/
public function current()
{
return $this->userList->getUser($this->key);
}
/**
* Move forward to next element
* @link http://php.net/manual/en/iterator.next.php
* @return void Any returned value is ignored.
*/
public function next()
{
$this->key++;
}
/**
* Return the key of the current element
* @link http://php.net/manual/en/iterator.key.php
* @return int scalar on success, or null on failure.
*/
public function key()
{
return $this->key;
}
/**
* Checks if current position is valid
* @link http://php.net/manual/en/iterator.valid.php
* @return boolean The return value will be casted to boolean and then evaluated.
* Returns true on success or false on failure.
*/
public function valid()
{
return $this->key() < $this->userList->count();
}
/**
* Rewind the Iterator to the first element
* @link http://php.net/manual/en/iterator.rewind.php
* @return void Any returned value is ignored.
*/
public function rewind()
{
$this->key = 0;
}
}