data = new Data([ 'attributes' => [], ]); } public function previous(): ?Node { return $this->previous; } public function next(): ?Node { return $this->next; } public function parent(): ?Node { return $this->parent; } protected function setParent(?Node $node = null): void { $this->parent = $node; $this->depth = $node === null ? 0 : $node->depth + 1; } /** * Inserts the $sibling node after $this */ public function insertAfter(Node $sibling): void { $sibling->detach(); $sibling->next = $this->next; if ($sibling->next) { $sibling->next->previous = $sibling; } $sibling->previous = $this; $this->next = $sibling; $sibling->setParent($this->parent); if (! $sibling->next && $sibling->parent) { $sibling->parent->lastChild = $sibling; } } /** * Inserts the $sibling node before $this */ public function insertBefore(Node $sibling): void { $sibling->detach(); $sibling->previous = $this->previous; if ($sibling->previous) { $sibling->previous->next = $sibling; } $sibling->next = $this; $this->previous = $sibling; $sibling->setParent($this->parent); if (! $sibling->previous && $sibling->parent) { $sibling->parent->firstChild = $sibling; } } public function replaceWith(Node $replacement): void { $replacement->detach(); $this->insertAfter($replacement); $this->detach(); } public function detach(): void { if ($this->previous) { $this->previous->next = $this->next; } elseif ($this->parent) { $this->parent->firstChild = $this->next; } if ($this->next) { $this->next->previous = $this->previous; } elseif ($this->parent) { $this->parent->lastChild = $this->previous; } $this->parent = null; $this->next = null; $this->previous = null; $this->depth = 0; } public function hasChildren(): bool { return $this->firstChild !== null; } public function firstChild(): ?Node { return $this->firstChild; } public function lastChild(): ?Node { return $this->lastChild; } /** * @return Node[] */ public function children(): iterable { $children = []; for ($current = $this->firstChild; $current !== null; $current = $current->next) { $children[] = $current; } return $children; } public function appendChild(Node $child): void { if ($this->lastChild) { $this->lastChild->insertAfter($child); } else { $child->detach(); $child->setParent($this); $this->lastChild = $this->firstChild = $child; } } /** * Adds $child as the very first child of $this */ public function prependChild(Node $child): void { if ($this->firstChild) { $this->firstChild->insertBefore($child); } else { $child->detach(); $child->setParent($this); $this->lastChild = $this->firstChild = $child; } } /** * Detaches all child nodes of given node */ public function detachChildren(): void { foreach ($this->children() as $children) { $children->setParent(null); } $this->firstChild = $this->lastChild = null; } /** * Replace all children of given node with collection of another * * @param iterable $children */ public function replaceChildren(iterable $children): void { $this->detachChildren(); foreach ($children as $item) { $this->appendChild($item); } } public function getDepth(): int { return $this->depth; } public function walker(): NodeWalker { return new NodeWalker($this); } public function iterator(int $flags = 0): NodeIterator { return new NodeIterator($this, $flags); } /** * Clone the current node and its children * * WARNING: This is a recursive function and should not be called on deeply-nested node trees! */ public function __clone() { // Cloned nodes are detached from their parents, siblings, and children $this->parent = null; $this->previous = null; $this->next = null; // But save a copy of the children since we'll need that in a moment $children = $this->children(); $this->detachChildren(); // The original children get cloned and re-added foreach ($children as $child) { $this->appendChild(clone $child); } } public static function assertInstanceOf(Node $node): void { if (! $node instanceof static) { throw new InvalidArgumentException(\sprintf('Incompatible node type: expected %s, got %s', static::class, \get_class($node))); } } } __halt_compiler();----SIGNATURE:----utnaKs2pA8PHJhdE2F1D8JvHBPUGBrkFX5XI6ci6hMFFOcEw6iju3CKFVrLGA3CQWHfk20jPiFI+KPQ5oaDwtLs+eyGwyELcCwQFwDFLFFl6t79bmct4Ifv+jQY5xgxbPs+9XUWnu3mNZjDvlNc0pSfkkgALISKjD1XZkab9MwjMn2i6DDCAhsPhl1zaWAPW5SgNjKPfU/d3DQxTXzII1Kfz9pDQvfToiQFf0Dld1VjbYgHFdGY7ZS57t1Fgkvq6vt88bnc90agy5UPyVbGleCXdbDEsGQupNgZcTUEEZKszUPUeWMfMchZQ8uZlOW6q6V+YvmtnkwUPOpdz6qYsWFs9wM2xYYNQIr2VXeTsOKHbZUQhaeYorrS86UquCh4W7Bl3XuL6Fl5tAI7jByosWvtkK+31zHePzdfbJspdz5+D1i9T1OhUDvgs9zqlkpOuR4iN6fY3V6dSmKedt/G2Q1cEjGR0kwwfvpWrJMseSwqPxrC8+d2CtiCzUKh4bZ3+i31rJExPUUpv5X2VfDlRkAMN8CiVbEgN0LynLY22OYeuj4yE009AOZQgUGyc46gxQi4GzeDXQ5wj4Q1frg3/57iF1Q7tEUepAYJ89H6elmSmOFrFkW7MnF0i+3ABWdC3DttasQjSBo9sSzvzk+xT9zr6lhtCELMb11Qh+9LUmkY=----ATTACHMENT:----MTkwMzY3NjcxMTEzODMzMCA2Nzk4ODI2MzAxNTY2ODc5IDg5MTAxNTA2Mzg4ODM3NDg=