From 19b5033dc47694d9eda4c461501cfd5ff9df6e96 Mon Sep 17 00:00:00 2001 From: Andreas Kling Date: Mon, 21 Feb 2022 22:21:59 +0100 Subject: [PATCH] LibWeb: Implement Node.removeChild() in terms of "pre-remove" This is what the spec wants us to do. --- Userland/Libraries/LibWeb/DOM/Node.cpp | 8 +++++++- Userland/Libraries/LibWeb/DOM/Node.h | 2 ++ 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/Userland/Libraries/LibWeb/DOM/Node.cpp b/Userland/Libraries/LibWeb/DOM/Node.cpp index dff4980614..c15ebbc8e4 100644 --- a/Userland/Libraries/LibWeb/DOM/Node.cpp +++ b/Userland/Libraries/LibWeb/DOM/Node.cpp @@ -348,6 +348,12 @@ ExceptionOr> Node::pre_insert(NonnullRefPtr node, RefP return node; } +// https://dom.spec.whatwg.org/#dom-node-removechild +ExceptionOr> Node::remove_child(NonnullRefPtr child) +{ + return pre_remove(child); +} + // https://dom.spec.whatwg.org/#concept-node-pre-remove ExceptionOr> Node::pre_remove(NonnullRefPtr child) { @@ -383,7 +389,7 @@ void Node::remove(bool suppress_observers) // FIXME: Let oldPreviousSibling be node’s previous sibling. (Currently unused so not included) // FIXME: Let oldNextSibling be node’s next sibling. (Currently unused so not included) - parent->remove_child(*this); + parent->TreeNode::remove_child(*this); // FIXME: If node is assigned, then run assign slottables for node’s assigned slot. diff --git a/Userland/Libraries/LibWeb/DOM/Node.h b/Userland/Libraries/LibWeb/DOM/Node.h index 77ebef33f6..6f5c5a4a26 100644 --- a/Userland/Libraries/LibWeb/DOM/Node.h +++ b/Userland/Libraries/LibWeb/DOM/Node.h @@ -90,6 +90,8 @@ public: ExceptionOr> pre_remove(NonnullRefPtr); ExceptionOr> append_child(NonnullRefPtr); + ExceptionOr> remove_child(NonnullRefPtr); + void insert_before(NonnullRefPtr node, RefPtr child, bool suppress_observers = false); void remove(bool suppress_observers = false); void remove_all_children(bool suppress_observers = false);