| Conditions | 4 |
| Paths | 4 |
| Total Lines | 16 |
| Code Lines | 9 |
| Lines | 0 |
| Ratio | 0 % |
| Changes | 0 | ||
| 1 | <?php |
||
| 28 | public function resolve(ContainerInterface $container, array $params = []) |
||
| 29 | { |
||
| 30 | try { |
||
| 31 | /** @noinspection PhpMethodParametersCountMismatchInspection passing parameters for containers supporting them */ |
||
| 32 | $result = $container->get($this->class, $params); |
||
|
|
|||
| 33 | } catch (\Throwable $t) { |
||
| 34 | if ($this->optional) { |
||
| 35 | return null; |
||
| 36 | } |
||
| 37 | throw $t; |
||
| 38 | } |
||
| 39 | |||
| 40 | if (!$result instanceof $this->class) { |
||
| 41 | throw new InvalidConfigException('Container returned incorrect type for service ' . $this->class); |
||
| 42 | } |
||
| 43 | return $result; |
||
| 44 | } |
||
| 46 |
This check compares calls to functions or methods with their respective definitions. If the call has more arguments than are defined, it raises an issue.
If a function is defined several times with a different number of parameters, the check may pick up the wrong definition and report false positives. One codebase where this has been known to happen is Wordpress. Please note the @ignore annotation hint above.