GetClassTraits   A
last analyzed

Complexity

Total Complexity 6

Size/Duplication

Total Lines 63
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 1

Importance

Changes 0
Metric Value
c 0
b 0
f 0
dl 0
loc 63
rs 10
wmc 6
lcom 0
cbo 1

3 Methods

Rating   Name   Duplication   Size   Complexity  
A getClassTraits() 0 4 1
A from() 0 17 3
A getTraits() 0 12 2
1
<?php
2
3
/**
4
 * Copyright (c) 2015-present Ganbaro Digital Ltd
5
 * All rights reserved.
6
 *
7
 * Redistribution and use in source and binary forms, with or without
8
 * modification, are permitted provided that the following conditions
9
 * are met:
10
 *
11
 *   * Redistributions of source code must retain the above copyright
12
 *     notice, this list of conditions and the following disclaimer.
13
 *
14
 *   * Redistributions in binary form must reproduce the above copyright
15
 *     notice, this list of conditions and the following disclaimer in
16
 *     the documentation and/or other materials provided with the
17
 *     distribution.
18
 *
19
 *   * Neither the names of the copyright holders nor the names of his
20
 *     contributors may be used to endorse or promote products derived
21
 *     from this software without specific prior written permission.
22
 *
23
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
24
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
25
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
26
 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
27
 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
28
 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
29
 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
30
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
31
 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
32
 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
33
 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
34
 * POSSIBILITY OF SUCH DAMAGE.
35
 *
36
 * @category  Libraries
37
 * @package   MissingBits/Types
38
 * @author    Stuart Herbert <[email protected]>
39
 * @copyright 2015-present Ganbaro Digital Ltd www.ganbarodigital.com
40
 * @license   http://www.opensource.org/licenses/bsd-license.php  BSD License
41
 * @link      http://ganbarodigital.github.io/php-the-missing-bits
42
 */
43
44
namespace GanbaroDigital\MissingBits\TypeInspectors;
45
46
/**
47
 * get a full list of the traits used by a class or its parents
48
 */
49
class GetClassTraits
50
{
51
    /**
52
     * get a full list of the traits used by a class or its parents
53
     *
54
     * @param  string $item
55
     *         the item to examine
56
     * @return string[]
57
     *         the class's traits list
58
     */
59
    public function getClassTraits($item)
0 ignored issues
show
Coding Style Best Practice introduced by
Please use __construct() instead of a PHP4-style constructor that is named after the class.
Loading history...
60
    {
61
        return self::from($item);
62
    }
63
64
    /**
65
     * get a full list of the traits used by a class or its parents
66
     *
67
     * @param  string $item
68
     *         the item to examine
69
     * @return string[]
70
     *         the class's traits list
71
     */
72
    public static function from($item)
73
    {
74
        // let's start with a class hierarchy
75
        $classes = GetClassTypes::from($item);
76
        if (count($classes) === 0) {
77
            return [];
78
        }
79
80
        // let's get the list of traits for this hierarchy
81
        $retval = [];
82
        foreach ($classes as $className) {
83
            $retval = array_merge($retval, self::getTraits($className));
84
        }
85
86
        // all done
87
        return $retval;
88
    }
89
90
    /**
91
     * get a list of traits from a given class, and from the traits in
92
     * that class
93
     *
94
     * @param  string $className
95
     *         the class or trait to examine
96
     * @return string[]
97
     *         a list of the traits used by $className
98
     */
99
    private static function getTraits($className)
100
    {
101
        $retval = [];
102
        $traits = class_uses($className);
103
104
        foreach ($traits as $trait) {
105
            $retval[$trait] = $trait;
106
            $retval = array_merge($retval, self::getTraits($trait));
107
        }
108
109
        return $retval;
110
    }
111
}
112