PostOrder   A
last analyzed

Complexity

Total Complexity 3

Size/Duplication

Total Lines 25
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 0
Metric Value
eloc 8
dl 0
loc 25
ccs 8
cts 8
cp 1
rs 10
c 0
b 0
f 0
wmc 3

2 Methods

Rating   Name   Duplication   Size   Complexity  
A doTraverse() 0 8 2
A traverse() 0 5 1
1
<?php
2
3
/**
4
 * For the full copyright and license information, please view
5
 * the LICENSE file that was distributed with this source code.
6
 */
7
8
declare(strict_types=1);
9
10
namespace loophp\phptree\Traverser;
11
12
use loophp\phptree\Node\NodeInterface;
13
use Traversable;
14
15
/**
16
 * Class PostOrder.
17
 */
18
class PostOrder implements TraverserInterface
19
{
20
    /**
21
     * @var int
22
     */
23
    private $index = 0;
24
25 11
    public function traverse(NodeInterface $node): Traversable
26
    {
27 11
        $this->index = 0;
28
29 11
        return $this->doTraverse($node);
30
    }
31
32
    /**
33
     * @return Traversable<NodeInterface>
34
     */
35 11
    private function doTraverse(NodeInterface $node): Traversable
36
    {
37 11
        foreach ($node->children() as $child) {
38 11
            yield from $this->doTraverse($child);
39 11
            ++$this->index;
40
        }
41
42 11
        yield $this->index => $node;
43 11
    }
44
}
45