3v4l.org

run code in 300+ PHP versions simultaneously
<?php function isArrayFieldSet(array $array, $field, $separator = '/') { if (strpos($field, $separator) !== false) { $path = explode($separator, $field); $field = array_shift($path); if (!is_null($field) && isset($array[$field])) { if (count($path) > 0) { return isArrayFieldSet($array[$field], implode($separator, $path), $separator); } return true; } else { return false; } } return isset($array[$field]); } $array = [ 'a' => 'test', 'b' => [ 'b2' => 123, 'b3' => [ 'test' => true ] ] ]; $shouldPass = [ 'a', 'b', 'b/b2', 'b/b3', 'b/b3/test' ]; $shouldNotPass = [ 'c', 'b/b1', 'b/b2/bx', 'b/b3/test/x', 'c/L1', 'a/k15', ]; foreach ($shouldPass as $test) { isArrayFieldSet($array, $test, '/'); } foreach ($shouldNotPass as $test) { isArrayFieldSet($array, $test, '/'); }
Output for git.master, git.master_jit, rfc.property-hooks
Fatal error: Uncaught TypeError: isArrayFieldSet(): Argument #1 ($array) must be of type array, int given, called in /in/ehKEI on line 11 and defined in /in/ehKEI:3 Stack trace: #0 /in/ehKEI(11): isArrayFieldSet(123, 'bx', '/') #1 /in/ehKEI(11): isArrayFieldSet(Array, 'b2', '/') #2 /in/ehKEI(51): isArrayFieldSet(Array, 'b', '/') #3 {main} thrown in /in/ehKEI on line 3
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:
48.49 ms | 401 KiB | 8 Q