Passed
Push — master ( 5a4455...a3a054 )
by Pol
02:30
created

Vfs::add()   A

Complexity

Conditions 4
Paths 4

Size

Total Lines 21
Code Lines 9

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 8
CRAP Score 4.128

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 4
eloc 9
nc 4
nop 1
dl 0
loc 21
ccs 8
cts 10
cp 0.8
crap 4.128
rs 9.9666
c 1
b 0
f 0
1
<?php
2
3
declare(strict_types = 1);
4
5
namespace drupol\phpvfs\Node;
6
7
use drupol\phptree\Node\AttributeNode;
8
use drupol\phptree\Node\NodeInterface;
9
use drupol\phpvfs\Utils\Path;
10
11
/**
12
 * Class Vfs.
13
 */
14
abstract class Vfs extends AttributeNode implements VfsInterface
15
{
16
    /**
17
     * {@inheritdoc}
18
     *
19
     * @throws \Exception
20
     *
21
     * @return \drupol\phpvfs\Node\DirectoryInterface
22
     */
23 15
    public function add(NodeInterface ...$nodes): NodeInterface
24
    {
25
        /** @var \drupol\phpvfs\Node\VfsInterface $node */
26 15
        foreach ($nodes as $node) {
27 15
            if ($this->getAttribute('id') === $node->getAttribute('id')) {
0 ignored issues
show
Bug introduced by
The method getAttribute() does not exist on drupol\phptree\Node\NodeInterface. It seems like you code against a sub-type of drupol\phptree\Node\NodeInterface such as drupol\phptree\Node\AttributeNode or drupol\phptree\Node\AttributeNodeInterface or drupol\phptree\Node\AttributeNode. ( Ignorable by Annotation )

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

27
            if ($this->getAttribute('id') === $node->/** @scrutinizer ignore-call */ getAttribute('id')) {
Loading history...
28 5
                $this->add($node[0]->setParent(null));
29
30 5
                continue;
31
            }
32
33
            // If the $cwd contains the nodechild.
34 15
            if (null !== $child = $this->contains($node)) {
35
                $child->add($node[0]->setParent(null));
36
37
                continue;
38
            }
39
40 15
            parent::add($node->setParent(null));
41
        }
42
43 15
        return $this;
0 ignored issues
show
Bug Best Practice introduced by
The expression return $this returns the type drupol\phpvfs\Node\Vfs which is incompatible with the documented return type drupol\phpvfs\Node\DirectoryInterface.
Loading history...
44
    }
45
46
    /**
47
     * {@inheritdoc}
48
     */
49 1
    public function getPath(): Path
50
    {
51
        $paths = [
52 1
            $this->getAttribute('id'),
53
        ];
54
55 1
        foreach ($this->getAncestors() as $ancestor) {
56 1
            \array_unshift($paths, $ancestor->getAttribute('id'));
57
        }
58
59 1
        return Path::fromString(\str_replace('//', '/', \implode('/', $paths)));
60
    }
61
62
    /**
63
     * {@inheritdoc}
64
     */
65 14
    public function root(): VfsInterface
66
    {
67 14
        $root = $this;
68
69 14
        foreach ($this->getAncestors() as $ancestor) {
70 13
            $root = $ancestor;
71
        }
72
73 14
        return $root;
0 ignored issues
show
Bug Best Practice introduced by
The expression return $root could return the type drupol\phptree\Node\NodeInterface which includes types incompatible with the type-hinted return drupol\phpvfs\Node\VfsInterface. Consider adding an additional type-check to rule them out.
Loading history...
74
    }
75
76
    /**
77
     * @param \drupol\phpvfs\Node\VfsInterface $node
78
     *
79
     * @return null|\drupol\phpvfs\Node\VfsInterface
80
     */
81 15
    protected function contains(VfsInterface $node): ?VfsInterface
82
    {
83
        /** @var \drupol\phpvfs\Node\VfsInterface $child */
84 15
        foreach ($this->children() as $child) {
85 3
            if ($node->getAttribute('id') === $child->getAttribute('id')) {
0 ignored issues
show
Bug introduced by
The method getAttribute() does not exist on ArrayObject. ( Ignorable by Annotation )

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

85
            if ($node->getAttribute('id') === $child->/** @scrutinizer ignore-call */ getAttribute('id')) {

This check looks for calls to methods that do not seem to exist on a given type. It looks for the method on the type itself as well as in inherited classes or implemented interfaces.

This is most likely a typographical error or the method has been renamed.

Loading history...
86
                return $child;
0 ignored issues
show
Bug Best Practice introduced by
The expression return $child returns the type ArrayObject which is incompatible with the type-hinted return drupol\phpvfs\Node\VfsInterface|null.
Loading history...
87
            }
88
        }
89
90 15
        return null;
91
    }
92
}
93