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

HasMakesOffer   A

Complexity

Total Complexity 2

Size/Duplication

Total Lines 31
Duplicated Lines 0 %

Test Coverage

Coverage 50%

Importance

Changes 0
Metric Value
eloc 12
dl 0
loc 31
ccs 6
cts 12
cp 0.5
rs 10
c 0
b 0
f 0
wmc 2

2 Methods

Rating   Name   Duplication   Size   Complexity  
A SetMakesOffer() 0 7 1
A GetMakesOffer() 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\Offer;
10
use SignpostMarv\DaftObject\SchemaOrg\TypeUtilities;
11
12
trait HasMakesOffer
13
{
14
    use DaftObjectTrait;
15
16
    /**
17
    * @return array<int, Offer>
18
    */
19 10
    public function GetMakesOffer() : array
20
    {
21
        /**
22
        * @var array<int, Offer>
23
        */
24 10
        $out = TypeUtilities::ExpectRetrievedValueIsArray(
25 10
            'makesOffer',
26 10
            $this->RetrievePropertyValueFromData('makesOffer'),
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

26
            $this->/** @scrutinizer ignore-call */ 
27
                   RetrievePropertyValueFromData('makesOffer'),
Loading history...
27 10
            static::class
28
        );
29
30 10
        return $out;
31
    }
32
33
    /**
34
    * @param array<int, Offer> $value
35
    */
36
    public function SetMakesOffer(array $value) : void
37
    {
38
        $this->NudgePropertyWithUniqueValuesOfThings(
39
            'makesOffer',
40
            __METHOD__,
41
            $value,
42
            Offer::class
43
        );
44
    }
45
}
46