Passed
Push — 1.6 ( c2a002 )
by Luis
05:37
created

InterfaceDefinitionBuilder::buildParents()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 5
Code Lines 3

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 3
CRAP Score 1

Importance

Changes 0
Metric Value
cc 1
eloc 3
nc 1
nop 1
dl 0
loc 5
ccs 3
cts 3
cp 1
crap 1
rs 9.4285
c 0
b 0
f 0
1
<?php
2
/**
3
 * PHP version 7.1
4
 *
5
 * This source file is subject to the license that is bundled with this package in the file LICENSE.
6
 */
7
8
namespace PhUml\Parser\Code\Builders;
9
10
use PhpParser\Node\Stmt\Interface_;
11
use PhUml\Code\InterfaceDefinition;
12
use PhUml\Code\Name as InterfaceDefinitionName;
13
use PhUml\Parser\Code\Builders\Names\InterfaceNamesBuilder;
14
15
/**
16
 * It builds an `InterfaceDefinition`
17
 *
18
 * @see MembersBuilder
19
 * @see InterfaceNamesBuilder
20
 */
21
class InterfaceDefinitionBuilder
22
{
23
    use InterfaceNamesBuilder;
24
25
    /** @var MembersBuilder */
26
    private $membersBuilder;
27
28 129
    public function __construct(MembersBuilder $membersBuilder = null)
29
    {
30 129
        $this->membersBuilder = $membersBuilder ?? new MembersBuilder();
31 129
    }
32
33 48
    public function build(Interface_ $interface): InterfaceDefinition
34
    {
35 48
        return new InterfaceDefinition(
36 48
            InterfaceDefinitionName::from($interface->name),
0 ignored issues
show
Bug introduced by
It seems like $interface->name can also be of type null; however, parameter $text of PhUml\Code\Name::from() does only seem to accept string, 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

36
            InterfaceDefinitionName::from(/** @scrutinizer ignore-type */ $interface->name),
Loading history...
37 48
            $this->membersBuilder->methods($interface->getMethods()),
38 48
            $this->membersBuilder->constants($interface->stmts),
39 48
            $this->buildInterfaces($interface->extends)
40
        );
41
    }
42
}
43