ReversedComparator::__construct()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 3
CRAP Score 1

Importance

Changes 1
Bugs 0 Features 0
Metric Value
c 1
b 0
f 0
dl 0
loc 4
ccs 3
cts 3
cp 1
rs 10
cc 1
eloc 2
nc 1
nop 1
crap 1
1
<?php
2
/*
3
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
4
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
5
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
6
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
7
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
8
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
9
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
10
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
11
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
12
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
13
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
14
 *
15
 * This software consists of voluntary contributions made by many individuals
16
 * and is licensed under the MIT license. For more information, see
17
 * <http://www.doctrine-project.org>.
18
 */
19
20
namespace Baleen\Migrations\Delta\Comparator;
21
22
use Baleen\Migrations\Delta\DeltaInterface;
23
24
/**
25
 * Class ReversedComparator
26
 *
27
 * @author Gabriel Somoza <[email protected]>
28
 */
29
final class ReversedComparator extends AbstractComparator
30
{
31
    /** @var ComparatorInterface */
32
    private $internalComparator;
33
34
    /**
35
     * ReversedComparator constructor.
36
     *
37
     * @param ComparatorInterface $internalComparator The comparator to reverse.
38
     */
39 11
    public function __construct(ComparatorInterface $internalComparator)
40
    {
41 11
        $this->internalComparator = $internalComparator;
42 11
    }
43
44
    /**
45
     * Compares two versions with each other using the internal comparator, and returns the opposite result.
46
     *
47
     * @param DeltaInterface $version1
48
     * @param DeltaInterface $version2
49
     *
50
     * @return int
51
     */
52 6
    public function compare(DeltaInterface $version1, DeltaInterface $version2)
53
    {
54 6
        return $this->internalComparator->compare($version1, $version2) * -1;
55
    }
56
57
    /**
58
     * Returns a comparator that sorts in the opposite direction.
59
     *
60
     * @return static
61
     */
62
    public function getReverse()
63
    {
64
        return $this->internalComparator;
65
    }
66
}
67