Total Complexity | 10 |
Total Lines | 59 |
Duplicated Lines | 0 % |
Coverage | 78.95% |
Changes | 1 | ||
Bugs | 0 | Features | 1 |
1 | <?php |
||
9 | class Oop |
||
10 | { |
||
11 | |||
12 | /** |
||
13 | * @param $class |
||
14 | * @return string |
||
15 | */ |
||
16 | 1 | public static function basename($class) |
|
17 | { |
||
18 | 1 | $class = is_object($class) ? get_class($class) : $class; |
|
19 | |||
20 | 1 | return basename(str_replace('\\', '/', $class)); |
|
21 | } |
||
22 | |||
23 | /** |
||
24 | * @param $class |
||
25 | * @param bool $recursive |
||
26 | * @return array |
||
27 | */ |
||
28 | 1 | public static function uses($class, $recursive = true) |
|
29 | { |
||
30 | 1 | if (is_object($class)) { |
|
31 | $class = get_class($class); |
||
32 | } |
||
33 | 1 | if (class_exists($class) && $recursive == false) { |
|
|
|||
34 | return class_uses($class); |
||
35 | } |
||
36 | 1 | $results = []; |
|
37 | |||
38 | 1 | foreach (array_reverse(class_parents($class)) + [$class => $class] as $class) { |
|
39 | 1 | $results += static::traitUses($class); |
|
40 | } |
||
41 | |||
42 | 1 | return array_unique($results); |
|
43 | } |
||
44 | |||
45 | /** |
||
46 | * @param $trait |
||
47 | * @param bool $recursive |
||
48 | * @return array |
||
49 | */ |
||
50 | 1 | public static function traitUses($trait, $recursive = true) |
|
51 | { |
||
52 | 1 | $traits = class_uses($trait); |
|
53 | |||
54 | 1 | foreach ($traits as $trait) { |
|
55 | 1 | $traits += static::traitUses($trait); |
|
56 | } |
||
57 | |||
58 | 1 | return $traits; |
|
59 | } |
||
60 | |||
61 | /** |
||
62 | * @param $name |
||
63 | * @return bool |
||
64 | */ |
||
65 | public static function isTrait($name) |
||
68 | } |
||
69 | } |
When comparing two booleans, it is generally considered safer to use the strict comparison operator.