3v4l.org

run code in 300+ PHP versions simultaneously
<?php trait OuterIteratorTrait { private $inner; /** * @return bool */ function isEmpty() { $iterator = clone $this->inner; $iterator->rewind(); return !$iterator->valid(); } function rewind() { $this->inner->rewind(); } function valid() { return $this->inner->valid(); } function next() { $this->inner->next(); } function current() { return $this->inner->current(); } function key() { return $this->inner->key(); } } class MappingIterator implements Iterator { use OuterIteratorTrait; private $mapper; function __construct(\Iterator $i, callable $f) { $this->inner = $i; $this->mapper = $f; } function current() { return call_user_func($this->mapper, $this->inner->current(), $this->key()); } } $i = new ArrayIterator(array(0, 2, 4)); $mapper = new MappingIterator($i, function($val){ return 2 * $val;}); var_dump(iterator_to_array($mapper));
Output for 8.1.0 - 8.1.28, 8.2.0 - 8.2.18, 8.3.0 - 8.3.6
Deprecated: Return type of MappingIterator::current() should either be compatible with Iterator::current(): mixed, or the #[\ReturnTypeWillChange] attribute should be used to temporarily suppress the notice in /in/F29gc on line 58 Deprecated: Return type of MappingIterator::next() should either be compatible with Iterator::next(): void, or the #[\ReturnTypeWillChange] attribute should be used to temporarily suppress the notice in /in/F29gc on line 28 Deprecated: Return type of MappingIterator::key() should either be compatible with Iterator::key(): mixed, or the #[\ReturnTypeWillChange] attribute should be used to temporarily suppress the notice in /in/F29gc on line 38 Deprecated: Return type of MappingIterator::valid() should either be compatible with Iterator::valid(): bool, or the #[\ReturnTypeWillChange] attribute should be used to temporarily suppress the notice in /in/F29gc on line 23 Deprecated: Return type of MappingIterator::rewind() should either be compatible with Iterator::rewind(): void, or the #[\ReturnTypeWillChange] attribute should be used to temporarily suppress the notice in /in/F29gc on line 18 array(3) { [0]=> int(0) [1]=> int(4) [2]=> int(8) }
Output for 5.4.0 - 5.4.45, 5.5.24 - 5.5.35, 5.6.7 - 5.6.28, 7.0.0 - 7.0.20, 7.1.0 - 7.1.20, 7.2.0 - 7.2.33, 7.3.12 - 7.3.33, 7.4.0 - 7.4.33, 8.0.0 - 8.0.30
array(3) { [0]=> int(0) [1]=> int(4) [2]=> int(8) }
Output for 4.4.2 - 4.4.9, 5.1.0 - 5.1.6, 5.2.0 - 5.2.17, 5.3.0 - 5.3.29
Parse error: syntax error, unexpected T_STRING in /in/F29gc on line 3
Process exited with code 255.
Output for 4.3.0 - 4.3.1, 4.3.5 - 4.3.11, 4.4.0 - 4.4.1, 5.0.0 - 5.0.5
Parse error: parse error, unexpected T_STRING in /in/F29gc on line 3
Process exited with code 255.
Output for 4.3.2 - 4.3.4
Parse error: parse error in /in/F29gc on line 3
Process exited with code 255.

preferences:
192.42 ms | 401 KiB | 314 Q