mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-04-26 22:38:51 +00:00
LibWeb+LibJS: Make the EventTarget hierarchy (incl. DOM) GC-allocated
This is a monster patch that turns all EventTargets into GC-allocated PlatformObjects. Their C++ wrapper classes are removed, and the LibJS garbage collector is now responsible for their lifetimes. There's a fair amount of hacks and band-aids in this patch, and we'll have a lot of cleanup to do after this.
This commit is contained in:
parent
bb547ce1c4
commit
6f433c8656
Notes:
sideshowbarker
2024-07-17 07:28:15 +09:00
Author: https://github.com/awesomekling
Commit: 6f433c8656
Pull-request: https://github.com/SerenityOS/serenity/pull/14816
Reviewed-by: https://github.com/ADKaster
Reviewed-by: https://github.com/linusg ✅
445 changed files with 4797 additions and 4268 deletions
|
@ -20,11 +20,14 @@ HTMLOptionsCollection::HTMLOptionsCollection(DOM::ParentNode& root, Function<boo
|
|||
// https://html.spec.whatwg.org/multipage/common-dom-interfaces.html#dom-htmloptionscollection-add
|
||||
DOM::ExceptionOr<void> HTMLOptionsCollection::add(HTMLOptionOrOptGroupElement element, Optional<HTMLElementOrElementIndex> before)
|
||||
{
|
||||
auto resolved_element = element.visit([](auto const& e) -> NonnullRefPtr<HTMLElement> { return e; });
|
||||
auto resolved_element = element.visit(
|
||||
[](auto& e) -> JS::Handle<HTMLElement> {
|
||||
return JS::make_handle(static_cast<HTML::HTMLElement&>(*e));
|
||||
});
|
||||
|
||||
RefPtr<DOM::Node> before_element;
|
||||
if (before.has_value() && before->has<NonnullRefPtr<HTMLElement>>())
|
||||
before_element = before->get<NonnullRefPtr<HTMLElement>>();
|
||||
JS::GCPtr<DOM::Node> before_element;
|
||||
if (before.has_value() && before->has<JS::Handle<HTMLElement>>())
|
||||
before_element = before->get<JS::Handle<HTMLElement>>().ptr();
|
||||
|
||||
// 1. If element is an ancestor of the select element on which the HTMLOptionsCollection is rooted, then throw a "HierarchyRequestError" DOMException.
|
||||
if (resolved_element->is_ancestor_of(root()))
|
||||
|
@ -39,7 +42,7 @@ DOM::ExceptionOr<void> HTMLOptionsCollection::add(HTMLOptionOrOptGroupElement el
|
|||
return {};
|
||||
|
||||
// 4. If before is a node, then let reference be that node. Otherwise, if before is an integer, and there is a beforeth node in the collection, let reference be that node. Otherwise, let reference be null.
|
||||
RefPtr<DOM::Node> reference;
|
||||
JS::GCPtr<DOM::Node> reference;
|
||||
|
||||
if (before_element)
|
||||
reference = move(before_element);
|
||||
|
@ -50,7 +53,7 @@ DOM::ExceptionOr<void> HTMLOptionsCollection::add(HTMLOptionOrOptGroupElement el
|
|||
DOM::Node* parent = reference ? reference->parent() : root().ptr();
|
||||
|
||||
// 6. Pre-insert element into parent node before reference.
|
||||
(void)TRY(parent->pre_insert(resolved_element, reference));
|
||||
(void)TRY(parent->pre_insert(*resolved_element, reference));
|
||||
|
||||
return {};
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue