GetObjectTypes   A
last analyzed

Complexity

Total Complexity 6

Size/Duplication

Total Lines 78
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 1

Importance

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

3 Methods

Rating   Name   Duplication   Size   Complexity  
A getObjectTypes() 0 4 1
A from() 0 22 2
A getObjectConditionalTypes() 0 12 3
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
use stdClass;
47
48
class GetObjectTypes
49
{
50
    /**
51
     * the extra items that *might* be part of an object's type list
52
     * @var array
53
     */
54
    private static $objectConditionalExtras = [
55
        "__toString" => "string",
56
        "__invoke"   => "callable",
57
    ];
58
59
    /**
60
     * get a full list of an objects's inheritence hierarchy and other types
61
     * that it can satisfy
62
     *
63
     * @param  object $item
64
     *         the item to examine
65
     * @return string[]
66
     *         the object's list of types
67
     */
68
    public function getObjectTypes($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...
69
    {
70
        return self::from($item);
71
    }
72
73
    /**
74
     * get a full list of an objects's inheritence hierarchy and other types
75
     * that it can satisfy
76
     *
77
     * @param  object $item
78
     *         the item to examine
79
     * @return string[]
80
     *         the object's list of types
81
     */
82
    public static function from($item)
83
    {
84
        // robustness!
85
        if (!is_object($item)) {
86
            return [];
87
        }
88
89
        $className = get_class($item);
90
91
        // our details are made up of this order:
92
        //
93
        // 1. details about the class
94
        // 2. that we are an object
95
        // 3. any magic methods that can be automatically taken advantage of
96
        // 4. the default fallback type
97
        $retval = array_merge(
98
            GetClassTypes::from($className),
99
            self::getObjectConditionalTypes($item)
100
        );
101
102
        return $retval;
103
    }
104
105
    /**
106
     * get the list of extra types that are valid for this specific object
107
     *
108
     * @param  object $object
109
     *         the object to examine
110
     * @return string[]
111
     *         a (possibly empty) list of types for this object
112
     */
113
    private static function getObjectConditionalTypes($object)
114
    {
115
        $retval = [];
116
117
        foreach (self::$objectConditionalExtras as $methodName => $type) {
118
            if (method_exists($object, $methodName)) {
119
                $retval[$type] = $type;
120
            }
121
        }
122
123
        return $retval;
124
    }
125
}
126