3v4l.org

run code in 300+ PHP versions simultaneously
<?php abstract class MakeMeCMS_Addon_Abstract { static protected $_ver = 0.1; static protected $_list = []; static protected function add($addon) { self::$_list += [$addon=>$addon]; } static protected function check($addon) { if(isset($_list[$addon]) && class_exists($_list[$addon].'_Master') && method_exists($_list[$addon].'_Master', Main())): return true; else: return false; endif; } } class MakeMeCMS_Addon_Override extends MakeMeCMS_Addon_Abstract { public function get($what) { if(isset(parent::$what)): return parent::$what; endif; } } class MakeMeCMS_Addon_Call { private $_state = false; public function set($arg) { $this->_state = $arg; } public function state() { return $this->_state; } } class myAddon_Master extends MakeMeCMS_Addon_Abstract { static public $callable_from_templates = true; static public function Main(MakeMeCMS_Addon_Call $call) { parent::add('myAddon'); $call->set(true); return $call; } static public function hello() { echo('Hello World!'); } } $sysCall = new MakeMeCMS_Addon_Call; myAddon_Master::Main($sysCall); if(null !== MakeMeCMS_Addon_Override::get($_list['myAddon'])): myAddon::hello(); endif;
Output for git.master, git.master_jit, rfc.property-hooks
Fatal error: Uncaught Error: Non-static method MakeMeCMS_Addon_Override::get() cannot be called statically in /in/7AkGs:46 Stack trace: #0 {main} thrown in /in/7AkGs on line 46
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:
58.23 ms | 401 KiB | 8 Q