Completed
Push — master ( 22fd50...798002 )
by Neomerx
03:53
created

ScalarEquals   A

Complexity

Total Complexity 5

Size/Duplication

Total Lines 31
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 1

Importance

Changes 0
Metric Value
wmc 5
lcom 0
cbo 1
dl 0
loc 31
rs 10
c 0
b 0
f 0

3 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 5 1
A compare() 0 6 2
A isValidType() 0 4 2
1
<?php namespace Limoncello\Validation\Rules\Comparisons;
2
3
/**
4
 * Copyright 2015-2017 [email protected]
5
 *
6
 * Licensed under the Apache License, Version 2.0 (the "License");
7
 * you may not use this file except in compliance with the License.
8
 * You may obtain a copy of the License at
9
 *
10
 * http://www.apache.org/licenses/LICENSE-2.0
11
 *
12
 * Unless required by applicable law or agreed to in writing, software
13
 * distributed under the License is distributed on an "AS IS" BASIS,
14
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
 * See the License for the specific language governing permissions and
16
 * limitations under the License.
17
 */
18
19
use Limoncello\Validation\Contracts\Errors\ContextKeys;
20
use Limoncello\Validation\Contracts\Errors\ErrorCodes;
21
use Limoncello\Validation\Contracts\Execution\ContextInterface;
22
23
/**
24
 * @package Limoncello\Validation
25
 */
26
final class ScalarEquals extends BaseOneValueComparision
27
{
28
    /**
29
     * @param mixed $value
30
     */
31
    public function __construct($value)
32
    {
33
        assert(static::isValidType($value) === true);
0 ignored issues
show
Comprehensibility introduced by
Since Limoncello\Validation\Ru...omparisons\ScalarEquals is declared final, using late-static binding will have no effect. You might want to replace static with self instead.

Late static binding only has effect in subclasses. A final class cannot be extended anymore so late static binding cannot occurr. Consider replacing static:: with self::.

To learn more about late static binding, please refer to the PHP core documentation.

Loading history...
34
        parent::__construct($value, ErrorCodes::SCALAR_EQUALS, [ContextKeys::SCALAR_VALUE => $value]);
35
    }
36
37
    /**
38
     * @inheritdoc
39
     */
40
    public static function compare($value, ContextInterface $context): bool
41
    {
42
        $result = static::isValidType($value) === true && $value === static::readValue($context);
0 ignored issues
show
Comprehensibility introduced by
Since Limoncello\Validation\Ru...omparisons\ScalarEquals is declared final, using late-static binding will have no effect. You might want to replace static with self instead.

Late static binding only has effect in subclasses. A final class cannot be extended anymore so late static binding cannot occurr. Consider replacing static:: with self::.

To learn more about late static binding, please refer to the PHP core documentation.

Loading history...
43
44
        return $result;
45
    }
46
47
    /**
48
     * @param mixed $value
49
     *
50
     * @return bool
51
     */
52
    private static function isValidType($value): bool
53
    {
54
        return is_scalar($value) === true || $value === null;
55
    }
56
}
57