Passed
Pull Request — master (#192)
by Sergei
02:09
created

FieldStaticFactory   A

Complexity

Total Complexity 4

Size/Duplication

Total Lines 23
Duplicated Lines 0 %

Test Coverage

Coverage 83.33%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 7
c 1
b 0
f 0
dl 0
loc 23
ccs 5
cts 6
cp 0.8333
rs 10
wmc 4

3 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 2 1
A initialize() 0 4 1
A factory() 0 9 2
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Yiisoft\Form;
6
7
use RuntimeException;
8
9
final class FieldStaticFactory
10
{
11
    private static ?FieldFactory $factory = null;
12
13
    private function __construct()
14
    {
15
    }
16
17 8
    public static function initialize(array $parameters = []): void
18
    {
19
        /** @psalm-suppress MixedArgument */
20 8
        self::$factory = new FieldFactory(...$parameters);
0 ignored issues
show
Bug introduced by
$parameters is expanded, but the parameter $containerTag of Yiisoft\Form\FieldFactory::__construct() does not expect variable arguments. ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-type  annotation

20
        self::$factory = new FieldFactory(/** @scrutinizer ignore-type */ ...$parameters);
Loading history...
21
    }
22
23 8
    public static function factory(): FieldFactory
24
    {
25 8
        if (self::$factory === null) {
26
            throw new RuntimeException(
27
                'Field factory should be initialized with FieldStaticFactory::initialize() call.',
28
            );
29
        }
30
31 8
        return self::$factory;
32
    }
33
}
34