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

ClassCollection::unserializeAllowedClasses()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 1
CRAP Score 1

Importance

Changes 0
Metric Value
eloc 1
c 0
b 0
f 0
dl 0
loc 3
rs 10
ccs 1
cts 1
cp 1
cc 1
nc 1
nop 0
crap 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