1 | <?php |
||
8 | trait HasMakeMapper |
||
9 | { |
||
10 | /** |
||
11 | * Get the registered name of the component. |
||
12 | * |
||
13 | * @return string |
||
14 | */ |
||
15 | protected static function getFacadeAccessor() |
||
19 | |||
20 | /** |
||
21 | * Make new instance. |
||
22 | * |
||
23 | * @param array $arguments |
||
24 | * |
||
25 | * @throws InvalidParameterException |
||
26 | * |
||
27 | * @return object |
||
28 | */ |
||
29 | public static function make(array $arguments = []) |
||
42 | |||
43 | /** |
||
44 | * Compose make() parameters. |
||
45 | * |
||
46 | * @param array $parameters |
||
47 | * @param array $arguments |
||
48 | * |
||
49 | * @throws InvalidParameterException |
||
50 | * |
||
51 | * @return array |
||
52 | */ |
||
53 | protected static function composeMakeParameters(array $parameters, array $arguments = []): array |
||
77 | } |
||
78 |
Adding an explicit array definition is generally preferable to implicit array definition as it guarantees a stable state of the code.
Let’s take a look at an example:
As you can see in this example, the array
$myArray
is initialized the first time when the foreach loop is entered. You can also see that the value of thebar
key is only written conditionally; thus, its value might result from a previous iteration.This might or might not be intended. To make your intention clear, your code more readible and to avoid accidental bugs, we recommend to add an explicit initialization $myArray = array() either outside or inside the foreach loop.