Conditions | 4 |
Paths | 3 |
Total Lines | 19 |
Code Lines | 10 |
Lines | 0 |
Ratio | 0 % |
Changes | 0 |
1 | <?php |
||
10 | public function selectsProjectors(array $projectorClassNames, string $allProjectorsWarning): ?Collection |
||
11 | { |
||
12 | if (count($projectorClassNames ?? []) === 0) { |
||
13 | if (! $confirmed = $this->confirm($allProjectorsWarning)) { |
||
|
|||
14 | return null; |
||
15 | }; |
||
16 | |||
17 | return EventProjectionist::getProjectors(); |
||
18 | } |
||
19 | |||
20 | return collect($projectorClassNames) |
||
21 | ->map(function (string $projectorName) { |
||
22 | if (!$projector = $this->eventProjectionist->getProjector($projectorName)) { |
||
23 | throw new Exception("Projector {$projectorName} not found. Did you register it?"); |
||
24 | } |
||
25 | |||
26 | return $projector; |
||
27 | }); |
||
28 | } |
||
29 | } |
This check looks for methods that are used by a trait but not required by it.
To illustrate, let’s look at the following code example
The trait
Idable
provides a methodequalsId
that in turn relies on the methodgetId()
. If this method does not exist on a class mixing in this trait, the method will fail.Adding the
getId()
as an abstract method to the trait will make sure it is available.