MediaWiki REL1_34
MappedIterator Class Reference

Convenience class for generating iterators from iterators. More...

Inheritance diagram for MappedIterator:
Collaboration diagram for MappedIterator:

Public Member Functions

 __construct ( $iter, $vCallback, array $options=[])
 Build an new iterator from a base iterator by having the former wrap the later, returning the result of "value" callback for each current() invocation.
 
 accept ()
 
 current ()
 
 key ()
 
 next ()
 
 rewind ()
 
 valid ()
 

Protected Member Functions

 init ()
 Obviate the usual need for rewind() before using a FilterIterator in a manual loop.
 

Protected Attributes

callable $aCallback
 
array $cache = []
 
 $rewound = false
 
callable $vCallback
 

Detailed Description

Convenience class for generating iterators from iterators.

Since
1.21

Definition at line 28 of file MappedIterator.php.

Constructor & Destructor Documentation

◆ __construct()

MappedIterator::__construct (   $iter,
  $vCallback,
array  $options = [] 
)

Build an new iterator from a base iterator by having the former wrap the later, returning the result of "value" callback for each current() invocation.

The callback takes the result of current() on the base iterator as an argument. The keys of the base iterator are reused verbatim.

An "accept" callback can also be provided which will be called for each value in the base iterator (post-callback) and will return true if that value should be included in iteration of the MappedIterator (otherwise it will be filtered out).

Parameters
Iterator | array$iter
callable$vCallbackValue transformation callback
array$optionsOptions map (includes "accept") (since 1.22) -param array{accept?:callable} $options
Exceptions
UnexpectedValueException

Definition at line 54 of file MappedIterator.php.

References $vCallback.

Member Function Documentation

◆ accept()

MappedIterator::accept ( )

Definition at line 78 of file MappedIterator.php.

References $aCallback, and current().

◆ current()

MappedIterator::current ( )

Definition at line 100 of file MappedIterator.php.

References init().

Referenced by accept().

◆ init()

MappedIterator::init ( )
protected

Obviate the usual need for rewind() before using a FilterIterator in a manual loop.

Definition at line 112 of file MappedIterator.php.

References rewind().

Referenced by current(), key(), and valid().

◆ key()

MappedIterator::key ( )

Definition at line 88 of file MappedIterator.php.

References init().

◆ next()

MappedIterator::next ( )

Definition at line 67 of file MappedIterator.php.

◆ rewind()

MappedIterator::rewind ( )

Definition at line 72 of file MappedIterator.php.

Referenced by init().

◆ valid()

MappedIterator::valid ( )

Definition at line 94 of file MappedIterator.php.

References init().

Member Data Documentation

◆ $aCallback

callable MappedIterator::$aCallback
protected

Definition at line 32 of file MappedIterator.php.

Referenced by accept().

◆ $cache

array MappedIterator::$cache = []
protected

Definition at line 34 of file MappedIterator.php.

◆ $rewound

MappedIterator::$rewound = false
protected

Definition at line 36 of file MappedIterator.php.

◆ $vCallback

callable MappedIterator::$vCallback
protected

Definition at line 30 of file MappedIterator.php.

Referenced by __construct().


The documentation for this class was generated from the following file: