Completed
Push — master ( 258d90...7630d0 )
by David
04:59
created

ReflectionUtils::getClass()   A

Complexity

Conditions 3
Paths 3

Size

Total Lines 14
Code Lines 7

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 4
CRAP Score 3.7086

Importance

Changes 3
Bugs 1 Features 0
Metric Value
c 3
b 1
f 0
dl 0
loc 14
ccs 4
cts 7
cp 0.5714
rs 9.4286
cc 3
eloc 7
nc 3
nop 1
crap 3.7086
1
<?php
2
3
/*
4
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
5
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
6
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
7
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
8
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
9
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
10
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
11
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
12
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
13
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
14
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
15
 *
16
 * The software is based on the Axon Framework project which is
17
 * licensed under the Apache 2.0 license. For more information on the Axon Framework
18
 * see <http://www.axonframework.org/>.
19
 * 
20
 * This software consists of voluntary contributions made by many individuals
21
 * and is licensed under the MIT license. For more information, see
22
 * <http://www.governor-framework.org/>.
23
 */
24
25
namespace Governor\Framework\Common;
26
27
/**
28
 * Utility class providing some basic convinience mehtods build on top of the PHP Reflection API.
29
 *
30
 * @author    "David Kalosi" <[email protected]>  
31
 * @license   <a href="http://www.opensource.org/licenses/mit-license.php">MIT License</a> 
32
 */
33
class ReflectionUtils
34
{
35
36
    /**
37
     * Returns a list of all properties declared in either the $class or any of its parents.
38
     * 
39
     * @param \ReflectionClass $class
40
     * @return \ReflectionProperty[]
41
     */
42 42
    public static function getProperties(\ReflectionClass $class)
43
    {
44 42
        $current = $class;
45 42
        $result = array();
46
47
        do {
48 42
            $result = array_merge($result, $current->getProperties());
49 42
            $current = $current->getParentClass();
50 42
        } while ($current);
51
52 42
        return $result;
53
    }
54
55
    /**
56
     * Returns a list of public methods declared in either the $class or any of its parents.
57
     * 
58
     * @param \ReflectionClass $class
59
     * @return \ReflectionMethod[]
60
     */
61 52
    public static function getMethods(\ReflectionClass $class)
62
    {
63
        return
64 52
            $class->getMethods(\ReflectionMethod::IS_PUBLIC);
65
    }
66
67
    /**
68
     * Returns a reflection class for the object. If the object is an Orm Proxy it returns the parent class.
69
     *
70
     * @param string|mixed $object
71
     * @return \ReflectionClass
72
     */
73 46
    public static function getClass ($object)
74
    {
75 46
        $reflectionClass = new \ReflectionClass($object);
76
77 46
        if (!class_exists('Doctrine\ORM\Proxy\Proxy')) {
78 46
            return $reflectionClass;
79
        }
80
81
        if ($reflectionClass->implementsInterface('Doctrine\ORM\Proxy\Proxy')) {
82
            return $reflectionClass->getParentClass();
83
        }
84
85
        return $reflectionClass;
86
    }
87
88
}
89