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 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93
|
<?php
namespace MediaWiki\HookContainer;
use InvalidArgumentException;
use LogicException;
use OutOfBoundsException;
/**
* @internal
*/
class FauxHookHandlerArray implements \ArrayAccess, \IteratorAggregate {
private HookContainer $hookContainer;
private string $name;
private ?array $handlers = null;
/**
* @param HookContainer $hookContainer
* @param string $name
*/
public function __construct( HookContainer $hookContainer, string $name ) {
$this->hookContainer = $hookContainer;
$this->name = $name;
}
/**
* @inheritDoc
*/
#[\ReturnTypeWillChange]
public function offsetExists( $offset ) {
return $this->getHandler( $offset ) !== null;
}
/**
* @inheritDoc
*/
#[\ReturnTypeWillChange]
public function offsetGet( $offset ) {
$handler = $this->getHandler( $offset );
if ( !$handler ) {
throw new OutOfBoundsException( "No such index in the handler list: $offset" );
}
return $handler;
}
/**
* @inheritDoc
*/
#[\ReturnTypeWillChange]
public function offsetSet( $offset, $value ) {
if ( $offset !== null ) {
throw new InvalidArgumentException( '$offset must be null, this array is append only' );
}
$this->hookContainer->register( $this->name, $value );
$this->handlers = null;
}
/**
* @inheritDoc
* @return never
*/
#[\ReturnTypeWillChange]
public function offsetUnset( $offset ) {
throw new LogicException( 'unset is not supported for hook handler arrays' );
}
private function getHandler( $offset ) {
if ( $this->handlers === null ) {
// NOTE: getHandlerCallbacks() only exists to support this.
// It should be deleted when we no longer need it here.
$this->handlers = $this->hookContainer->getHandlerCallbacks( $this->name );
}
return $this->handlers[$offset] ?? null;
}
#[\ReturnTypeWillChange]
public function getIterator() {
if ( $this->handlers === null ) {
// NOTE: getHandlerCallbacks() only exists to support this.
// It should be deleted when we no longer need it here.
$this->handlers = $this->hookContainer->getHandlerCallbacks( $this->name );
}
return new \ArrayIterator( $this->handlers );
}
}
|