Passed
Push — master ( d2cc23...a71a12 )
by Gabriel
03:43
created

ClassCollection   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 32
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 1
Bugs 0 Features 1
Metric Value
wmc 3
eloc 10
c 1
b 0
f 1
dl 0
loc 32
rs 10
ccs 7
cts 7
cp 1

3 Methods

Rating   Name   Duplication   Size   Complexity  
A validClass() 0 3 1
A unserializeAllowedClasses() 0 3 1
A __construct() 0 6 1
1
<?php
2
3
namespace Nip\Collections\Typed;
4
5
/**
6
 * Class ClassCollection
7
 * @package Nip\Collections\Typed
8
 */
9
class ClassCollection extends AbstractTypedCollection
10
{
11
    protected $serializable = ['items', 'type', 'validClass'];
12
13
    public const TYPE = 'class';
14
15
    protected $type = self::TYPE;
16
    protected $validClass = null;
17
18
    /**
19
     * ClassCollection constructor.
20 4
     * @param array $items
21
     */
22
    public function __construct($items = [])
23 4
    {
24
        $this->typeChecker = function ($element) {
25 4
            return ($element instanceof $this->validClass);
26 4
        };
27
        parent::__construct($items);
28
    }
29
30
    protected function unserializeAllowedClasses()
31
    {
32 4
        return [$this->validClass];
33
    }
34 4
35 4
    /**
36
     * @param null $validClass
0 ignored issues
show
Documentation Bug introduced by
Are you sure the doc-type for parameter $validClass is correct as it would always require null to be passed?
Loading history...
37
     */
38
    public function validClass($validClass): void
39
    {
40
        $this->validClass = $validClass;
41
    }
42
}
43