3v4l.org

run code in 300+ PHP versions simultaneously
<?php $list = json_decode(<<<'JSON' [ { "TagId": 2, "ParentTagId": null, "Name": "women" }, { "TagId": 5, "ParentTagId": 2, "Name": "bottom" }, { "TagId": 4, "ParentTagId": 2, "Name": "top" }, { "TagId": 7, "ParentTagId": 4, "Name": "shirt" }, { "TagId": 8, "ParentTagId": 4, "Name": "tshirt" }, { "TagId": 12, "ParentTagId": 7, "Name": "longsleeve" }, { "TagId": 16, "ParentTagId": null, "Name": "men" } ] JSON ); class Trie implements IteratorAggregate { protected $parent; protected $children = []; public function insert(Node $node) { $node->parent = $this; $this->children[] = $node; } public function findById($id) { foreach($this->children as $childNode) { if ($childNode->TagId === $id) { return $childNode; } } } public function hasChildren() { return (bool) count($this->children); } public function getIterator() { return $this->children; } } class Node extends Trie { public function __construct(stdClass $obj) { foreach($obj as $p => $v) { $this->$p = $v; } } } $trie = new Trie; /* Insert all of the parentless nodes */ foreach($list as $n => $obj) { if (!$obj->ParentTagId) { $trie->insert(new Node($obj)); unset($list[$n]); } } /* Insert all of the child nodes */ foreach($list as $n => $obj) { $p = $trie->findById($obj->ParentTagId); if ($p) { $p->insert(new Node($obj)); unset($list[$n]); } } var_dump(json_encode($trie));
Output for 8.2.0 - 8.2.18, 8.3.0 - 8.3.4, 8.3.6
Deprecated: Return type of Trie::getIterator() should either be compatible with IteratorAggregate::getIterator(): Traversable, or the #[\ReturnTypeWillChange] attribute should be used to temporarily suppress the notice in /in/FfOGj on line 40 Deprecated: Creation of dynamic property Node::$TagId is deprecated in /in/FfOGj on line 51 Deprecated: Creation of dynamic property Node::$ParentTagId is deprecated in /in/FfOGj on line 51 Deprecated: Creation of dynamic property Node::$Name is deprecated in /in/FfOGj on line 51 Deprecated: Creation of dynamic property Node::$TagId is deprecated in /in/FfOGj on line 51 Deprecated: Creation of dynamic property Node::$ParentTagId is deprecated in /in/FfOGj on line 51 Deprecated: Creation of dynamic property Node::$Name is deprecated in /in/FfOGj on line 51 Deprecated: Creation of dynamic property Node::$TagId is deprecated in /in/FfOGj on line 51 Deprecated: Creation of dynamic property Node::$ParentTagId is deprecated in /in/FfOGj on line 51 Deprecated: Creation of dynamic property Node::$Name is deprecated in /in/FfOGj on line 51 Deprecated: Creation of dynamic property Node::$TagId is deprecated in /in/FfOGj on line 51 Deprecated: Creation of dynamic property Node::$ParentTagId is deprecated in /in/FfOGj on line 51 Deprecated: Creation of dynamic property Node::$Name is deprecated in /in/FfOGj on line 51 string(2) "{}"
Output for 8.3.5
Warning: PHP Startup: Unable to load dynamic library 'sodium.so' (tried: /usr/lib/php/8.3.5/modules/sodium.so (libsodium.so.23: cannot open shared object file: No such file or directory), /usr/lib/php/8.3.5/modules/sodium.so.so (/usr/lib/php/8.3.5/modules/sodium.so.so: cannot open shared object file: No such file or directory)) in Unknown on line 0 Deprecated: Return type of Trie::getIterator() should either be compatible with IteratorAggregate::getIterator(): Traversable, or the #[\ReturnTypeWillChange] attribute should be used to temporarily suppress the notice in /in/FfOGj on line 40 Deprecated: Creation of dynamic property Node::$TagId is deprecated in /in/FfOGj on line 51 Deprecated: Creation of dynamic property Node::$ParentTagId is deprecated in /in/FfOGj on line 51 Deprecated: Creation of dynamic property Node::$Name is deprecated in /in/FfOGj on line 51 Deprecated: Creation of dynamic property Node::$TagId is deprecated in /in/FfOGj on line 51 Deprecated: Creation of dynamic property Node::$ParentTagId is deprecated in /in/FfOGj on line 51 Deprecated: Creation of dynamic property Node::$Name is deprecated in /in/FfOGj on line 51 Deprecated: Creation of dynamic property Node::$TagId is deprecated in /in/FfOGj on line 51 Deprecated: Creation of dynamic property Node::$ParentTagId is deprecated in /in/FfOGj on line 51 Deprecated: Creation of dynamic property Node::$Name is deprecated in /in/FfOGj on line 51 Deprecated: Creation of dynamic property Node::$TagId is deprecated in /in/FfOGj on line 51 Deprecated: Creation of dynamic property Node::$ParentTagId is deprecated in /in/FfOGj on line 51 Deprecated: Creation of dynamic property Node::$Name is deprecated in /in/FfOGj on line 51 string(2) "{}"
Output for 8.1.0 - 8.1.28
Deprecated: Return type of Trie::getIterator() should either be compatible with IteratorAggregate::getIterator(): Traversable, or the #[\ReturnTypeWillChange] attribute should be used to temporarily suppress the notice in /in/FfOGj on line 40 string(2) "{}"
Output for 5.5.0 - 5.5.38, 5.6.0 - 5.6.38, 7.0.0 - 7.0.33, 7.1.0 - 7.1.25, 7.2.0 - 7.2.33, 7.3.0 - 7.3.33, 7.4.0 - 7.4.33, 8.0.0 - 8.0.30
string(2) "{}"

preferences:
228.74 ms | 403 KiB | 293 Q