3v4l.org

run code in 300+ PHP versions simultaneously
<?php class Context { private $context = null; private $data = []; public function __construct(Context $context = null) { $this->context = $context; } public function get($name) { if (isset($this->data[$name])) { return $this->data[$name]; } if (isset($this->context)) { return $this->context->get($name); } return null; } public function getAll(array $names) { $data = []; foreach ($names as $name) { $data[$name] = $this->get($name); } return $data; } public function set($name, $value) { $this->data[$name] = $value; } public function wrap() { return new Context($this); } public function call(callable $function) { call_user_func($function, $this); } } (new Context)->call(function(Context $c) { $c->set('foo', 1); $c->set('bar', 2); $c->wrap()->call(function(Context $c) { $c->set('bar', 3); $c->set('qux', 4); $c->wrap()->call(function(Context $c) { $c->set('qux', 5); $c->set('zip', 6); var_dump($c->getAll()); }); var_dump($c->getAll()); }); var_dump($c->getAll()); });
Output for git.master, git.master_jit, rfc.property-hooks
Fatal error: Uncaught ArgumentCountError: Too few arguments to function Context::getAll(), 0 passed in /in/29KXu on line 53 and exactly 1 expected in /in/29KXu:22 Stack trace: #0 /in/29KXu(53): Context->getAll() #1 /in/29KXu(39): {closure}(Object(Context)) #2 /in/29KXu(50): Context->call(Object(Closure)) #3 /in/29KXu(39): {closure}(Object(Context)) #4 /in/29KXu(47): Context->call(Object(Closure)) #5 /in/29KXu(39): {closure}(Object(Context)) #6 /in/29KXu(44): Context->call(Object(Closure)) #7 {main} thrown in /in/29KXu on line 22
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:
41.69 ms | 401 KiB | 8 Q