Completed
Pull Request — master (#38)
by Marco
03:08
created

MultiPropertyBased::compare()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 8
Code Lines 5

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 8
rs 9.4285
c 0
b 0
f 0
cc 1
eloc 5
nc 1
nop 2
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Roave\ApiCompare\Comparator\BackwardsCompatibility\PropertyBased;
6
7
use Roave\ApiCompare\Changes;
8
use Roave\BetterReflection\Reflection\ReflectionProperty;
9
10
final class MultiPropertyBased implements PropertyBased
11
{
12
    /** @var PropertyBased[] */
13
    private $checks;
14
15
    public function __construct(PropertyBased ...$checks)
16
    {
17
        $this->checks = $checks;
18
    }
19
20
    public function compare(ReflectionProperty $fromProperty, ReflectionProperty $toProperty) : Changes
21
    {
22
        return array_reduce(
23
            $this->checks,
24
            function (Changes $changes, PropertyBased $check) use ($fromProperty, $toProperty) : Changes {
25
                return $changes->mergeWith($check->compare($fromProperty, $toProperty));
26
            },
27
            Changes::new()
28
        );
29
    }
30
}
31