File: FauxHookHandlerArray.php

package info (click to toggle)
mediawiki 1%3A1.43.3%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 417,464 kB
  • sloc: php: 1,062,949; javascript: 664,290; sql: 9,714; python: 5,458; xml: 3,489; sh: 1,131; makefile: 64
file content (93 lines) | stat: -rw-r--r-- 2,153 bytes parent folder | download
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 );
	}
}