@ 2012-11-21T19:39:41Z <?php
class Controller {
public function testAction()
{
}
public static function staticAction()
{
}
public function __call($method, $arguments)
{
}
}
$calls = array(
array('Controller', 'testAction'),
array('Controller', 'staticAction'),
array('Controller', 'fooAction'),
array(new Controller, 'testAction'),
array(new Controller, 'staticAction'),
array(new Controller, 'fooAction'),
);
foreach($calls as $controller)
{
$data = array();
try {
$r = new ReflectionMethod($controller[0], $controller[1]);
$data['controller'] = array(
'class' => is_object($controller[0]) ? get_class($controller[0]) : $controller[0],
'method' => $controller[1],
'file' => $r->getFilename(),
'line' => $r->getStartLine(),
);
} catch (ReflectionException $re) {
if (is_callable($controller) || method_exists($controller[0], '__call')) {
$r = new ReflectionClass($controller[0]);
// using __call magic
$data['controller'] = array(
'class' => is_object($controller[0]) ? get_class($controller[0]) : $controller[0],
'method' => $controller[1],
'file' => $r->getFilename(),
'line' => $r->getMethod('__call')->getStartLine(),
);
}
}
var_dump($data);
}
Enable javascript to submit You have javascript disabled. You will not be able to edit any code.
Output for 5.0.0 - 5.0.5 , 5.1.0 - 5.1.6 , 5.2.0 - 5.2.17 , 5.3.0 - 5.3.29 , 5.4.0 - 5.4.45 , 5.5.0 - 5.5.36 , 5.6.0 - 5.6.28 , 7.0.0 - 7.0.20 , 7.1.0 - 7.1.33 , 7.2.0 - 7.2.33 , 7.3.0 - 7.3.33 , 7.4.0 - 7.4.33 , 8.0.0 - 8.0.30 , 8.1.0 - 8.1.28 , 8.2.0 - 8.2.18 , 8.3.0 - 8.3.6 array(1) {
["controller"]=>
array(4) {
["class"]=>
string(10) "Controller"
["method"]=>
string(10) "testAction"
["file"]=>
string(9) "/in/tmC0X"
["line"]=>
int(5)
}
}
array(1) {
["controller"]=>
array(4) {
["class"]=>
string(10) "Controller"
["method"]=>
string(12) "staticAction"
["file"]=>
string(9) "/in/tmC0X"
["line"]=>
int(10)
}
}
array(1) {
["controller"]=>
array(4) {
["class"]=>
string(10) "Controller"
["method"]=>
string(9) "fooAction"
["file"]=>
string(9) "/in/tmC0X"
["line"]=>
int(15)
}
}
array(1) {
["controller"]=>
array(4) {
["class"]=>
string(10) "Controller"
["method"]=>
string(10) "testAction"
["file"]=>
string(9) "/in/tmC0X"
["line"]=>
int(5)
}
}
array(1) {
["controller"]=>
array(4) {
["class"]=>
string(10) "Controller"
["method"]=>
string(12) "staticAction"
["file"]=>
string(9) "/in/tmC0X"
["line"]=>
int(10)
}
}
array(1) {
["controller"]=>
array(4) {
["class"]=>
string(10) "Controller"
["method"]=>
string(9) "fooAction"
["file"]=>
string(9) "/in/tmC0X"
["line"]=>
int(15)
}
}
Output for 4.4.2 - 4.4.9 Parse error: syntax error, unexpected T_STRING, expecting T_OLD_FUNCTION or T_FUNCTION or T_VAR or '}' in /in/tmC0X on line 5
Process exited with code 255 . Output for 4.3.0 - 4.3.1 , 4.3.5 - 4.3.11 , 4.4.0 - 4.4.1 Parse error: parse error, unexpected T_STRING, expecting T_OLD_FUNCTION or T_FUNCTION or T_VAR or '}' in /in/tmC0X on line 5
Process exited with code 255 . Output for 4.3.2 - 4.3.4 Parse error: parse error, expecting `T_OLD_FUNCTION' or `T_FUNCTION' or `T_VAR' or `'}'' in /in/tmC0X on line 5
Process exited with code 255 . preferences:dark mode live preview
236.78 ms | 401 KiB | 392 Q