C:\xampp\htdocs\landing\wp-content\plugins\amp\src\DevTools\CallbackReflection.php


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
<?php
/**
 * Class CallbackReflection.
 *
 * @package AmpProject\AmpWP
 */

namespace AmpProject\AmpWP\DevTools;

use 
AmpProject\AmpWP\Infrastructure\Service;
use 
Exception;
use 
ReflectionFunction;
use 
ReflectionMethod;
use 
Reflector;

/**
 * Reflect on a file to deduce its type of source (plugin, theme, core).
 *
 * @package AmpProject\AmpWP
 * @since 2.0.2
 * @internal
 */
final class CallbackReflection implements Service {

    
/**
     * File reflection instance to use.
     *
     * @var FileReflection
     */
    
private $file_reflection;

    
/**
     * CallbackReflection constructor.
     *
     * @param FileReflection $file_reflection File reflector to use.
     */
    
public function __constructFileReflection $file_reflection ) {
        
$this->file_reflection $file_reflection;
    }

    
/**
     * Gets the plugin or theme of the callback, if one exists.
     *
     * @param string|array|callable $callback The callback for which to get the
     *                                        plugin.
     * @return array|null {
     *     The source data.
     *
     *     @type string    $type       Source type (core, plugin, mu-plugin, or theme).
     *     @type string    $name       Source name.
     *     @type string    $file       Relative file path based on the type.
     *     @type string    $function   Normalized function name.
     *     @type Reflector $reflection Reflection.
     * }
     */
    
public function get_source$callback ) {
        
$reflection $this->get_reflection$callback );

        if ( ! 
$reflection ) {
            return 
null;
        }

        
$source = [ 'reflection' => $reflection ];

        
$file   wp_normalize_path$reflection->getFileName() );
        
$source array_merge(
            
$source,
            
$this->file_reflection->get_file_source$file )
        );

        
// If a file was identified, then also supply the line number.
        
if ( isset( $source['file'] ) ) {
            
$source['line'] = $reflection->getStartLine();
        }

        if ( 
$reflection instanceof ReflectionMethod ) {
            
$source['function'] = $reflection->getDeclaringClass()->getName() . '::' $reflection->getName();
        } else {
            
$source['function'] = $reflection->getName();
        }

        return 
$source;
    }

    
/**
     * Get the reflection object for the callback.
     *
     * @param string|array|callable $callback The callback for which to get the
     *                                        plugin.
     * @return ReflectionMethod|ReflectionFunction|null
     */
    
private function get_reflection$callback ) {
        try {
            if ( 
is_string$callback ) && is_callable$callback ) ) {
                
// The $callback is a function or static method.
                
$exploded_callback explode'::'$callback);

                if ( 
!== count$exploded_callback ) ) {
                    return new 
ReflectionFunction$callback );
                }

                
// Since identified as method, handle as ReflectionMethod below.
                
$callback $exploded_callback;
            }

            if (
                
is_array$callback )
                &&
                isset( 
$callback[0], $callback[1] )
                &&
                
method_exists$callback[0], $callback[1] )
            ) {
                
$reflection = new ReflectionMethod$callback[0], $callback[1] );

                
// Handle the special case of the class being a widget, in which
                // case the display_callback method should actually map to the
                // underling widget method. It is the display_callback in the
                // end that is wrapped.
                
if (
                    
'display_callback' === $reflection->getName()
                    &&
                    
'WP_Widget' === $reflection->getDeclaringClass()->getName()
                ) {
                    return new 
ReflectionMethod$callback[0], 'widget' );
                }

                return 
$reflection;
            }

            if (
                
is_object$callback )
                &&
                
'Closure' === get_class$callback )
            ) {
                return new 
ReflectionFunction$callback );
            }
        } catch ( 
Exception $exception ) { // phpcs:ignore Generic.CodeAnalysis.EmptyStatement.DetectedCatch
            // Don't let exceptions through here.
        
}

        return 
null;
    }
}
x

Windows NT KPTV 6.2 build 9200 (Windows Server 2012 Datacenter Edition) i586