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

MultiPropertyBased::__construct()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Importance

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