Passed
Push — master ( dda9e1...11d05c )
by Arkadiusz
02:19
created

Comparison::compare()   C

Complexity

Conditions 11
Paths 11

Size

Total Lines 25
Code Lines 22

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 25
rs 5.2653
c 0
b 0
f 0
cc 11
eloc 22
nc 11
nop 3

How to fix   Complexity   

Long Method

Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.

For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.

Commonly applied refactorings include:

1
<?php
2
3
declare(strict_types=1);
4
5
namespace Phpml\Math;
6
7
use Phpml\Exception\InvalidArgumentException;
8
9
class Comparison
10
{
11
    /**
12
     * @param mixed  $a
13
     * @param mixed  $b
14
     * @param string $operator
15
     *
16
     * @return bool
17
     *
18
     * @throws InvalidArgumentException
19
     */
20
    public static function compare($a, $b, string $operator): bool
21
    {
22
        switch ($operator) {
23
            case '>':
24
                return $a > $b;
25
            case '>=':
26
                return $a >= $b;
27
            case '=':
28
            case '==':
29
                return $a == $b;
30
            case '===':
31
                return $a === $b;
32
            case '<=':
33
                return $a <= $b;
34
            case '<':
35
                return $a < $b;
36
            case '!=':
37
            case '<>':
38
                return $a != $b;
39
            case '!==':
40
                return $a !== $b;
41
            default:
42
                throw InvalidArgumentException::invalidOperator($operator);
43
        }
44
    }
45
}
46