3v4l.org

run code in 300+ PHP versions simultaneously
<?php class CategoryTree { protected $roots = []; public function addCategory($category, $parent) { if ($this->categoryExists($this->roots, $category)) { throw new InvalidArgumentException(); } if ($parent === null) { $this->roots[$category] = []; return; } $node = $this->findNode($parent, $this->roots); if(!isset($node)) { throw new InvalidArgumentException("Parent node: $parent not found."); } $node[$category] = []; } public function getChildren($parent) { $node = $this->findNode($parent, $this->roots); if(!isset($node)) { throw new InvalidArgumentException(); } return array_keys($node); } public function findNode($node, &$root) { echo $node; print_r(array_keys($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($nodes 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'));
Output for 8.0.0 - 8.0.30, 8.1.0 - 8.1.27, 8.2.0 - 8.2.17, 8.3.0 - 8.3.4
Warning: Array to string conversion in /in/urEpP on line 35 ArrayArray ( [0] => A ) Warning: Array to string conversion in /in/urEpP on line 35 ArrayArray ( ) Fatal error: Uncaught InvalidArgumentException in /in/urEpP:29 Stack trace: #0 /in/urEpP(48): CategoryTree->getChildren(Array) #1 /in/urEpP(9): CategoryTree->categoryExists(Array, 'B') #2 /in/urEpP(60): CategoryTree->addCategory('B', 'A') #3 {main} thrown in /in/urEpP on line 29
Process exited with code 255.
Output for 7.0.0 - 7.0.20, 7.1.0 - 7.1.33, 7.2.0 - 7.2.33, 7.3.0 - 7.3.31, 7.4.0 - 7.4.33
Notice: Array to string conversion in /in/urEpP on line 35 ArrayArray ( [0] => A ) Notice: Array to string conversion in /in/urEpP on line 35 ArrayArray ( ) Fatal error: Uncaught InvalidArgumentException in /in/urEpP:29 Stack trace: #0 /in/urEpP(48): CategoryTree->getChildren(Array) #1 /in/urEpP(9): CategoryTree->categoryExists(Array, 'B') #2 /in/urEpP(60): CategoryTree->addCategory('B', 'A') #3 {main} thrown in /in/urEpP on line 29
Process exited with code 255.
Output for 7.3.32 - 7.3.33
ArrayArray ( [0] => A ) ArrayArray ( ) Fatal error: Uncaught InvalidArgumentException in /in/urEpP:29 Stack trace: #0 /in/urEpP(48): CategoryTree->getChildren(Array) #1 /in/urEpP(9): CategoryTree->categoryExists(Array, 'B') #2 /in/urEpP(60): CategoryTree->addCategory('B', 'A') #3 {main} thrown in /in/urEpP on line 29
Process exited with code 255.
Output for 5.5.0 - 5.5.38, 5.6.0 - 5.6.28
Notice: Array to string conversion in /in/urEpP on line 35 ArrayArray ( [0] => A ) Notice: Array to string conversion in /in/urEpP on line 35 ArrayArray ( ) Fatal error: Uncaught exception 'InvalidArgumentException' in /in/urEpP:29 Stack trace: #0 /in/urEpP(48): CategoryTree->getChildren(Array) #1 /in/urEpP(9): CategoryTree->categoryExists(Array, 'B') #2 /in/urEpP(60): CategoryTree->addCategory('B', 'A') #3 {main} thrown in /in/urEpP on line 29
Process exited with code 255.

preferences:
206.68 ms | 402 KiB | 251 Q