3v4l.org

run code in 300+ PHP versions simultaneously
<?php trait ClosureInATrait { public static function getConstInTrait() { return __LINE__; } } class ClassConstantTest { use ClosureInATrait; public static function getConstInClass() { return __CLASS__; } } $closureInClass = (new ReflectionMethod('ClassConstantTest','getConstInClass'))->getClosure(); $closureInTrait = (new ReflectionMethod('ClassConstantTest','getConstInTrait'))->getClosure(); echo 'Closure before bind: ' . PHP_EOL; echo 'Class closure: ' . PHP_EOL; var_dump($closureInClass()); echo 'Trait closure: ' . PHP_EOL; var_dump($closureInTrait()); $closureInClass = Closure::bind($closureInClass, null, 'stdClass'); $closureInTrait = Closure::bind($closureInTrait, null, 'stdClass'); echo 'Closure after bind: ' . PHP_EOL; echo 'Class closure: ' . PHP_EOL; var_dump($closureInClass()); echo 'Trait closure: ' . PHP_EOL; var_dump($closureInTrait());
Output for git.master, git.master_jit, rfc.property-hooks
Closure before bind: Class closure: string(17) "ClassConstantTest" Trait closure: int(7) Warning: Cannot bind closure to scope of internal class stdClass in /in/aDcb4 on line 30 Warning: Cannot bind closure to scope of internal class stdClass in /in/aDcb4 on line 31 Closure after bind: Class closure: Fatal error: Uncaught Error: Value of type null is not callable in /in/aDcb4:35 Stack trace: #0 {main} thrown in /in/aDcb4 on line 35
Process exited with code 255.

This tab shows result from various feature-branches currently under review by the php developers. Contact me to have additional branches featured.

Active branches

Archived branches

Once feature-branches are merged or declined, they are no longer available. Their functionality (when merged) can be viewed from the main output page


preferences:
36.65 ms | 402 KiB | 8 Q