Completed
Pull Request — master (#30)
by Marco
01:47
created

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