3v4l.org

run code in 200+ php & hhvm versions
Bugs & Features
<?php class CategoryTree { protected $roots = []; public function addCategory($category, $parent) { if ($this->categoryExists($this->roots, $category) || !$this->categoryExists($this->roots, $parent)) { throw new InvalidArgumentException(); } if ($parent === null) { $this->tree[$category] = []; } $node = $findNode($parent, $this->root); if(!isset($node)) { throw new InvalidArgumentException(); } $node[$category] = []; } public function getChildren($parent) { $node = $findNode($parent, $this->root); if(!isset($node)) { throw new InvalidArgumentException(); } return array_keys($node); } public function findNode($node, &$root) { if (in_array($node, array_keys($root))) { return $root[$node]; } foreach ($root as $n) { return $this->findNode($node, $n); } } public function categoryExists($nodes, $category) { $exists = false; foreach($node as $node) { if (in_array($category, $this->getChildren($node))) { return true; } $exists = $this->categoryExists($node, $category); } return $exists; } } // For testing purposes (do not submit uncommented): $c = new CategoryTree; $c->addCategory('A', null); $c->addCategory('B', 'A'); $c->addCategory('C', 'A'); //echo implode(',', $c->getChildren('A'));
based on WbI8E
Output for 7.0.0 - 7.2.0
Notice: Undefined variable: node in /in/UEpV2 on line 43 Warning: Invalid argument supplied for foreach() in /in/UEpV2 on line 43 Notice: Undefined variable: node in /in/UEpV2 on line 43 Warning: Invalid argument supplied for foreach() in /in/UEpV2 on line 43 Fatal error: Uncaught InvalidArgumentException in /in/UEpV2:9 Stack trace: #0 /in/UEpV2(55): CategoryTree->addCategory('A', NULL) #1 {main} thrown in /in/UEpV2 on line 9
Process exited with code 255.
Output for 5.4.10 - 5.6.28
Notice: Undefined variable: node in /in/UEpV2 on line 43 Warning: Invalid argument supplied for foreach() in /in/UEpV2 on line 43 Notice: Undefined variable: node in /in/UEpV2 on line 43 Warning: Invalid argument supplied for foreach() in /in/UEpV2 on line 43 Fatal error: Uncaught exception 'InvalidArgumentException' in /in/UEpV2:9 Stack trace: #0 /in/UEpV2(55): CategoryTree->addCategory('A', NULL) #1 {main} thrown in /in/UEpV2 on line 9
Process exited with code 255.
Output for 5.3.20 - 5.3.29
Parse error: syntax error, unexpected '[' in /in/UEpV2 on line 4
Process exited with code 255.