BreadthFirst   A
last analyzed

Complexity

Total Complexity 3

Size/Duplication

Total Lines 14
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

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

1 Method

Rating   Name   Duplication   Size   Complexity  
A traverse() 0 12 3
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 SplQueue;
14
use Traversable;
15
16
/**
17
 * Class BreadthFirst.
18
 */
19
class BreadthFirst implements TraverserInterface
20
{
21 18
    public function traverse(NodeInterface $node): Traversable
22
    {
23 18
        $queue = new SplQueue();
24 18
        $queue->enqueue($node);
25
26 18
        yield $node;
27
28 18
        while (0 < $queue->count()) {
29 18
            foreach ($queue->dequeue()->children() as $child) {
30 18
                $queue->enqueue($child);
31
32 18
                yield $child;
33
            }
34
        }
35 2
    }
36
}
37