Passed
Pull Request — master (#85)
by Sergei
02:32
created

Normalizer::parse()   C

Complexity

Conditions 12
Paths 17

Size

Total Lines 42
Code Lines 25

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 25
CRAP Score 12.0082

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 25
c 1
b 0
f 0
dl 0
loc 42
ccs 25
cts 26
cp 0.9615
rs 6.9666
cc 12
nc 17
nop 2
crap 12.0082

How to fix   Complexity   

Long Method

Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.

For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.

Commonly applied refactorings include:

1
<?php
2
3
declare(strict_types=1);
4
5
namespace Yiisoft\Factory\Definition;
6
7
use Yiisoft\Factory\Exception\InvalidConfigException;
8
9
use function array_key_exists;
10
use function is_array;
11
use function is_callable;
12
use function is_object;
13
use function is_string;
14
15
/**
16
 * Class Definition represents a definition in a container
17
 */
18
class Normalizer
19
{
20
    /**
21
     * Definition may be defined multiple ways.
22
     * Interface name as string:
23
     *
24
     * ```php
25
     * $container->set('interface_name', EngineInterface::class);
26
     * ```
27
     *
28
     * A closure:
29
     *
30
     * ```php
31
     * $container->set('closure', function($container) {
32
     *     return new MyClass($container->get('db'));
33
     * });
34
     * ```
35
     *
36
     * A callable array:
37
     *
38
     * ```php
39
     * $container->set('static_call', [MyClass::class, 'create']);
40
     * ```
41
     *
42
     * A definition array:
43
     *
44
     * ```php
45
     * $container->set('full_definition', [
46
     *     'class' => EngineMarkOne::class,
47
     *     '__construct()' => [42],
48
     *     '$argName' => 'value',
49
     *     'setX()' => [42],
50
     * ]);
51
     * ```
52
     *
53
     * @param mixed $definition
54
     *
55
     * @throws InvalidConfigException
56
     */
57 27
    public static function normalize($definition, string $id = null): DefinitionInterface
58
    {
59
        // Reference
60 27
        if ($definition instanceof ReferenceInterface) {
61 1
            return $definition;
62
        }
63
64 27
        if (is_string($definition)) {
65
            // Current class
66
            if (
67 20
                $id === $definition ||
68 20
                ($id === null && class_exists($definition))
69
            ) {
70
                /** @psalm-var class-string $definition */
71 12
                return ArrayDefinition::fromPreparedData($definition);
72
            }
73
74
            // Reference to another class or alias
75 8
            return Reference::to($definition);
76
        }
77
78
        // Callable definition
79 12
        if (is_callable($definition, true)) {
80 3
            return new CallableDefinition($definition);
81
        }
82
83
        // Array definition
84 9
        if (is_array($definition)) {
85 8
            $config = $definition;
86 8
            if (!array_key_exists(ArrayDefinition::CLASS_NAME, $config)) {
87 1
                $config[ArrayDefinition::CLASS_NAME] = $id;
88
            }
89
            /** @psalm-suppress ArgumentTypeCoercion */
90 8
            return ArrayDefinition::fromConfig($config);
91
        }
92
93
        // Ready object
94 1
        if (is_object($definition)) {
95 1
            return new ValueDefinition($definition);
96
        }
97
98
        throw new InvalidConfigException('Invalid definition:' . var_export($definition, true));
99
    }
100
}
101