Passed
Push — master ( df1a48...669ccb )
by SignpostMarv
04:37
created

HasDirector   A

Complexity

Total Complexity 2

Size/Duplication

Total Lines 27
Duplicated Lines 0 %

Test Coverage

Coverage 75%

Importance

Changes 0
Metric Value
eloc 8
dl 0
loc 27
ccs 6
cts 8
cp 0.75
rs 10
c 0
b 0
f 0
wmc 2

2 Methods

Rating   Name   Duplication   Size   Complexity  
A SetDirector() 0 3 1
A GetDirector() 0 12 1
1
<?php
2
/**
3
* @author SignpostMarv
4
*/
5
declare(strict_types=1);
6
7
namespace SignpostMarv\DaftObject\SchemaOrg\DaftObjectTraits;
8
9
use SignpostMarv\DaftObject\SchemaOrg\TypeUtilities;
10
11
trait HasDirector
12
{
13
    use DaftObjectTrait;
14
15
    /**
16
    * @return array<int, \SignpostMarv\DaftObject\SchemaOrg\Person>
17
    */
18 5
    public function GetDirector() : array
19
    {
20
        /**
21
        * @var array<int, \SignpostMarv\DaftObject\SchemaOrg\Person>
22
        */
23 5
        $out = TypeUtilities::ExpectRetrievedValueIsArray(
24 5
            'director',
25 5
            $this->RetrievePropertyValueFromData('director'),
0 ignored issues
show
Bug introduced by
It seems like RetrievePropertyValueFromData() must be provided by classes using this trait. How about adding it as abstract method to this trait? ( Ignorable by Annotation )

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

25
            $this->/** @scrutinizer ignore-call */ 
26
                   RetrievePropertyValueFromData('director'),
Loading history...
26 5
            static::class
27
        );
28
29 5
        return $out;
30
    }
31
32
    /**
33
    * @param array<int, \SignpostMarv\DaftObject\SchemaOrg\Person> $value
34
    */
35
    public function SetDirector(array $value) : void
36
    {
37
        $this->NudgePropertyWithUniquePersons('director', __METHOD__, $value);
0 ignored issues
show
Bug introduced by
The method NudgePropertyWithUniquePersons() does not exist on SignpostMarv\DaftObject\...bjectTraits\HasDirector. Did you maybe mean NudgePropertyWithUniqueValuesOfThings()? ( Ignorable by Annotation )

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

37
        $this->/** @scrutinizer ignore-call */ 
38
               NudgePropertyWithUniquePersons('director', __METHOD__, $value);

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...
38
    }
39
}
40