BooleanHelper   A
last analyzed

Complexity

Total Complexity 11

Size/Duplication

Total Lines 41
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 1

Importance

Changes 0
Metric Value
wmc 11
lcom 0
cbo 1
dl 0
loc 41
rs 10
c 0
b 0
f 0

2 Methods

Rating   Name   Duplication   Size   Complexity  
A isBoolean() 0 5 2
B parseString() 0 19 9
1
<?php
2
3
/*
4
 * This file is part of the core-library package.
5
 *
6
 * (c) 2018 WEBEWEB
7
 *
8
 * For the full copyright and license information, please view the LICENSE
9
 * file that was distributed with this source code.
10
 */
11
12
namespace WBW\Library\Core\Argument\Helper;
13
14
use WBW\Library\Core\Argument\Exception\BooleanArgumentException;
15
16
/**
17
 * Boolean helper.
18
 *
19
 * @author webeweb <https://github.com/webeweb/>
20
 * @package WBW\Library\Core\Argument\Helper
21
 */
22
class BooleanHelper {
23
24
    /**
25
     * Determines if a value is a boolean.
26
     *
27
     * @param mixed $value The value.
28
     * @return void
29
     * @throws BooleanArgumentException Throws a Boolean argument exception if the value is not of expected type.
30
     */
31
    public static function isBoolean($value): void {
32
        if (false === is_bool($value)) {
33
            throw new BooleanArgumentException($value);
34
        }
35
    }
36
37
    /**
38
     * Parse a string.
39
     *
40
     * @param string|null $value The string value.
41
     * @return bool Returns true in case of success, false otherwise.
42
     */
43
    public static function parseString(?string $value): bool {
44
45
        if (null === $value) {
46
            return false;
47
        }
48
49
        switch (strtolower($value)) {
50
            case "1":
51
            case "o":
52
            case "ok":
53
            case "oui":
54
            case "true":
55
            case "y":
56
            case "yes":
57
                return true;
58
        }
59
60
        return false;
61
    }
62
}
63