TypeFloat::validate()   A
last analyzed

Complexity

Conditions 4
Paths 4

Size

Total Lines 10
Code Lines 5

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 5
CRAP Score 4

Importance

Changes 1
Bugs 0 Features 0
Metric Value
c 1
b 0
f 0
dl 0
loc 10
ccs 5
cts 5
cp 1
rs 9.2
cc 4
eloc 5
nc 4
nop 1
crap 4
1
<?php
2
/**
3
 * This file is part of php-simple-request.
4
 *
5
 * php-simple-request is free software: you can redistribute it and/or modify
6
 * it under the terms of the GNU Lesser General Public License as published by
7
 * the Free Software Foundation, either version 3 of the License, or
8
 * (at your option) any later version.
9
 *
10
 * php-simple-request is distributed in the hope that it will be useful,
11
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
 * GNU General Public License for more details.
14
 *
15
 * You should have received a copy of the GNU General Public License
16
 * along with php-simple-request.  If not, see <http://www.gnu.org/licenses/>.
17
 */
18
namespace Mcustiel\SimpleRequest\Validator;
19
20
use Mcustiel\SimpleRequest\Interfaces\ValidatorInterface;
21
22
/**
23
 * Validates that a given value is a floating point number. If the
24
 * specification value is true it checks if it's strictly a float,
25
 * if false, an integer number is validated as a float.
26
 *
27
 * @author mcustiel
28
 */
29
class TypeFloat implements ValidatorInterface
30
{
31
    /**
32
     *
33
     * @var bool
34
     */
35
    private $strict = false;
36
37
    /**
38
     * {@inheritdoc}
39
     *
40
     * @see \Mcustiel\SimpleRequest\Interfaces\Specificable::setSpecification()
41
     */
42 81
    public function setSpecification($specification = null)
43
    {
44 81
        $this->strict = (boolean) $specification;
45 81
    }
46
47
    /**
48
     * {@inheritdoc}
49
     *
50
     * @see \Mcustiel\SimpleRequest\Interfaces\ValidatorInterface::validate()
51
     */
52 82
    public function validate($value)
53
    {
54 82
        if (!is_numeric($value)) {
55 3
            return false;
56
        }
57
        // Convert possible strings to number
58 81
        $number = $value + 0;
59
60 81
        return is_double($number) || !$this->strict && is_int($number);
61
    }
62
}
63