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

ClassResolverFactory   A

Complexity

Total Complexity 2

Size/Duplication

Total Lines 17
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 6
dl 0
loc 17
ccs 6
cts 6
cp 1
rs 10
c 1
b 0
f 0
wmc 2

2 Methods

Rating   Name   Duplication   Size   Complexity  
A createClassNameFinder() 0 4 1
A createFinderRules() 0 5 1
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