Code Coverage |
||||||||||
Lines |
Functions and Methods |
Classes and Traits |
||||||||
Total | |
0.00% |
0 / 63 |
|
0.00% |
0 / 4 |
CRAP | |
0.00% |
0 / 1 |
MutationRecord | |
0.00% |
0 / 63 |
|
0.00% |
0 / 4 |
812 | |
0.00% |
0 / 1 |
_getMissingProp | |
0.00% |
0 / 12 |
|
0.00% |
0 / 1 |
12 | |||
_setMissingProp | |
0.00% |
0 / 11 |
|
0.00% |
0 / 1 |
12 | |||
__get | |
0.00% |
0 / 20 |
|
0.00% |
0 / 1 |
132 | |||
__isset | |
0.00% |
0 / 20 |
|
0.00% |
0 / 1 |
132 |
1 | <?php |
2 | |
3 | // AUTOMATICALLY GENERATED. DO NOT EDIT. |
4 | // Use `composer build` to regenerate. |
5 | |
6 | namespace Wikimedia\IDLeDOM\Helper; |
7 | |
8 | trait MutationRecord { |
9 | |
10 | // Underscore is used to avoid conflicts with DOM-reserved names |
11 | // phpcs:disable PSR2.Methods.MethodDeclaration.Underscore |
12 | // phpcs:disable MediaWiki.NamingConventions.LowerCamelFunctionsName.FunctionName |
13 | |
14 | /** |
15 | * Handle an attempt to get a non-existing property on this |
16 | * object. The default implementation raises an exception |
17 | * but the implementor can choose a different behavior: |
18 | * return null (like JavaScript), dynamically create the |
19 | * property, etc. |
20 | * @param string $prop the name of the property requested |
21 | * @return mixed |
22 | */ |
23 | protected function _getMissingProp( string $prop ) { |
24 | $trace = debug_backtrace(); |
25 | while ( |
26 | count( $trace ) > 0 && |
27 | $trace[0]['function'] !== "__get" |
28 | ) { |
29 | array_shift( $trace ); |
30 | } |
31 | trigger_error( |
32 | 'Undefined property' . |
33 | ' via ' . ( $trace[0]['function'] ?? '' ) . '(): ' . $prop . |
34 | ' in ' . ( $trace[0]['file'] ?? '' ) . |
35 | ' on line ' . ( $trace[0]['line'] ?? '' ), |
36 | E_USER_NOTICE |
37 | ); |
38 | return null; |
39 | } |
40 | |
41 | /** |
42 | * Handle an attempt to set a non-existing property on this |
43 | * object. The default implementation raises an exception |
44 | * but the implementor can choose a different behavior: |
45 | * ignore the operation (like JavaScript), dynamically create |
46 | * the property, etc. |
47 | * @param string $prop the name of the property requested |
48 | * @param mixed $value the value to set |
49 | */ |
50 | protected function _setMissingProp( string $prop, $value ): void { |
51 | $trace = debug_backtrace(); |
52 | while ( |
53 | count( $trace ) > 0 && |
54 | $trace[0]['function'] !== "__set" |
55 | ) { |
56 | array_shift( $trace ); |
57 | } |
58 | trigger_error( |
59 | 'Undefined property' . |
60 | ' via ' . ( $trace[0]['function'] ?? '' ) . '(): ' . $prop . |
61 | ' in ' . ( $trace[0]['file'] ?? '' ) . |
62 | ' on line ' . ( $trace[0]['line'] ?? '' ), |
63 | E_USER_NOTICE |
64 | ); |
65 | } |
66 | |
67 | // phpcs:enable |
68 | |
69 | /** |
70 | * @param string $name |
71 | * @return mixed |
72 | */ |
73 | public function __get( string $name ) { |
74 | '@phan-var \Wikimedia\IDLeDOM\MutationRecord $this'; |
75 | // @var \Wikimedia\IDLeDOM\MutationRecord $this |
76 | switch ( $name ) { |
77 | case "type": |
78 | return $this->getType(); |
79 | case "target": |
80 | return $this->getTarget(); |
81 | case "addedNodes": |
82 | return $this->getAddedNodes(); |
83 | case "removedNodes": |
84 | return $this->getRemovedNodes(); |
85 | case "previousSibling": |
86 | return $this->getPreviousSibling(); |
87 | case "nextSibling": |
88 | return $this->getNextSibling(); |
89 | case "attributeName": |
90 | return $this->getAttributeName(); |
91 | case "attributeNamespace": |
92 | return $this->getAttributeNamespace(); |
93 | case "oldValue": |
94 | return $this->getOldValue(); |
95 | default: |
96 | break; |
97 | } |
98 | '@phan-var \Wikimedia\IDLeDOM\Helper\MutationRecord $this'; |
99 | // @var \Wikimedia\IDLeDOM\Helper\MutationRecord $this |
100 | return $this->_getMissingProp( $name ); |
101 | } |
102 | |
103 | /** |
104 | * @param string $name |
105 | * @return bool |
106 | */ |
107 | public function __isset( string $name ): bool { |
108 | '@phan-var \Wikimedia\IDLeDOM\MutationRecord $this'; |
109 | // @var \Wikimedia\IDLeDOM\MutationRecord $this |
110 | switch ( $name ) { |
111 | case "type": |
112 | return true; |
113 | case "target": |
114 | return true; |
115 | case "addedNodes": |
116 | return true; |
117 | case "removedNodes": |
118 | return true; |
119 | case "previousSibling": |
120 | return $this->getPreviousSibling() !== null; |
121 | case "nextSibling": |
122 | return $this->getNextSibling() !== null; |
123 | case "attributeName": |
124 | return $this->getAttributeName() !== null; |
125 | case "attributeNamespace": |
126 | return $this->getAttributeNamespace() !== null; |
127 | case "oldValue": |
128 | return $this->getOldValue() !== null; |
129 | default: |
130 | break; |
131 | } |
132 | return false; |
133 | } |
134 | |
135 | } |