Passed
Push — feature/reset-cache-from-class... ( b5ffe1 )
by Chema
03:59
created

Gacela::normalizeSetup()   A

Complexity

Conditions 3
Paths 3

Size

Total Lines 11
Code Lines 5

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 5
CRAP Score 3.0416

Importance

Changes 0
Metric Value
cc 3
eloc 5
nc 3
nop 1
dl 0
loc 11
rs 10
c 0
b 0
f 0
ccs 5
cts 6
cp 0.8333
crap 3.0416
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Gacela\Framework;
6
7
use Gacela\Framework\Bootstrap\GacelaConfig;
8
use Gacela\Framework\Bootstrap\SetupGacela;
9
use Gacela\Framework\Bootstrap\SetupGacelaInterface;
10
use Gacela\Framework\ClassResolver\AbstractClassResolver;
11
use Gacela\Framework\Config\Config;
12
13
use function is_callable;
14
15
final class Gacela
16
{
17
    /**
18
     * Define the entry point of Gacela.
19
     *
20
     * @param null|SetupGacelaInterface|callable(GacelaConfig):void $configFn SetupGacelaInterface is deprecated
21
     */
22 26
    public static function bootstrap(string $appRootDir, $configFn = null): void
23
    {
24 26
        if ($configFn instanceof SetupGacelaInterface) {
25
            trigger_deprecation(
26
                'gacela-project/gacela',
27
                '0.18',
28
                '`SetupGacelaInterface` is deprecated. Use `callable(GacelaConfig)` instead.'
29
            );
30
        }
31
32 26
        $setup = self::normalizeSetup($configFn);
33
34 26
        AbstractClassResolver::resetCache();
35
36 26
        Config::getInstance()
37 26
            ->setAppRootDir($appRootDir)
38 26
            ->setSetup($setup)
39 26
            ->init();
40
    }
41
42
    /**
43
     * @param null|SetupGacelaInterface|callable(GacelaConfig):void $configFn
44
     */
45 26
    private static function normalizeSetup($configFn): SetupGacelaInterface
46
    {
47 26
        if ($configFn === null) {
48 16
            return new SetupGacela();
49
        }
50
51 10
        if (is_callable($configFn)) {
52 10
            return SetupGacela::fromCallable($configFn);
0 ignored issues
show
Bug introduced by
It seems like $configFn can also be of type Gacela\Framework\Bootstrap\SetupGacelaInterface; however, parameter $setupGacelaFileFn of Gacela\Framework\Bootstr...pGacela::fromCallable() does only seem to accept callable, maybe add an additional type check? ( Ignorable by Annotation )

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

52
            return SetupGacela::fromCallable(/** @scrutinizer ignore-type */ $configFn);
Loading history...
53
        }
54
55
        return $configFn;
0 ignored issues
show
Bug Best Practice introduced by
The expression return $configFn could return the type callable which is incompatible with the type-hinted return Gacela\Framework\Bootstrap\SetupGacelaInterface. Consider adding an additional type-check to rule them out.
Loading history...
56
    }
57
}
58