Passed
Push — master ( 9630dc...59d7dc )
by Jesús
03:24 queued 18s
created

ClassResolverFactory::createClassNameFinder()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 3
CRAP Score 1

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 2
nc 1
nop 0
dl 0
loc 4
ccs 3
cts 3
cp 1
crap 1
rs 10
c 1
b 0
f 0
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Gacela\Framework\ClassResolver;
6
7
use Gacela\Framework\ClassResolver\ClassNameFinder\ClassNameFinder;
8
use Gacela\Framework\ClassResolver\ClassNameFinder\ClassNameFinderInterface;
9
use Gacela\Framework\ClassResolver\ClassNameFinder\Rule\FinderRuleInterface;
10
use Gacela\Framework\ClassResolver\ClassNameFinder\Rule\FinderRuleWithModulePrefix;
11
use Gacela\Framework\ClassResolver\ClassNameFinder\Rule\FinderRuleWithoutModulePrefix;
12
13
final class ClassResolverFactory
14
{
15 15
    public function createClassNameFinder(): ClassNameFinderInterface
16
    {
17 15
        return new ClassNameFinder(
18 15
            $this->createFinderRules(),
19
        );
20
    }
21
22
    /**
23
     * @return list<FinderRuleInterface>
24
     */
25 15
    private function createFinderRules(): array
26
    {
27
        return [
0 ignored issues
show
Bug Best Practice introduced by
The expression return array(new Gacela\...eWithoutModulePrefix()) returns the type array<integer,Gacela\Fra...uleWithoutModulePrefix> which is incompatible with the documented return type Gacela\Framework\ClassResolver\list.
Loading history...
28 15
            new FinderRuleWithModulePrefix(),
29 15
            new FinderRuleWithoutModulePrefix(),
30
        ];
31
    }
32
}
33