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

FieldStaticFactory::__construct()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 2
Code Lines 0

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 2

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 0
c 1
b 0
f 0
nc 1
nop 0
dl 0
loc 2
ccs 0
cts 0
cp 0
crap 2
rs 10
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