mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-06-02 00:13:02 +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
|
@ -5,6 +5,7 @@
|
|||
* SPDX-License-Identifier: BSD-2-Clause
|
||||
*/
|
||||
|
||||
#include <LibWeb/Bindings/HTMLStyleElementPrototype.h>
|
||||
#include <LibWeb/CSS/Parser/Parser.h>
|
||||
#include <LibWeb/DOM/Document.h>
|
||||
#include <LibWeb/HTML/HTMLStyleElement.h>
|
||||
|
@ -14,10 +15,17 @@ namespace Web::HTML {
|
|||
HTMLStyleElement::HTMLStyleElement(DOM::Document& document, DOM::QualifiedName qualified_name)
|
||||
: HTMLElement(document, move(qualified_name))
|
||||
{
|
||||
set_prototype(&window().ensure_web_prototype<Bindings::HTMLStyleElementPrototype>("HTMLStyleElement"));
|
||||
}
|
||||
|
||||
HTMLStyleElement::~HTMLStyleElement() = default;
|
||||
|
||||
void HTMLStyleElement::visit_edges(Cell::Visitor& visitor)
|
||||
{
|
||||
Base::visit_edges(visitor);
|
||||
visitor.visit(m_associated_css_style_sheet.ptr());
|
||||
}
|
||||
|
||||
void HTMLStyleElement::children_changed()
|
||||
{
|
||||
|
||||
|
@ -104,11 +112,11 @@ void HTMLStyleElement::update_a_style_block()
|
|||
// 1. Let element be the style element.
|
||||
// 2. If element has an associated CSS style sheet, remove the CSS style sheet in question.
|
||||
|
||||
if (m_associated_css_style_sheet.cell()) {
|
||||
if (m_associated_css_style_sheet) {
|
||||
remove_a_css_style_sheet(document(), *m_associated_css_style_sheet);
|
||||
|
||||
// FIXME: This should probably be handled by StyleSheet::set_owner_node().
|
||||
m_associated_css_style_sheet = {};
|
||||
m_associated_css_style_sheet = nullptr;
|
||||
}
|
||||
|
||||
// 3. If element is not connected, then return.
|
||||
|
@ -129,7 +137,7 @@ void HTMLStyleElement::update_a_style_block()
|
|||
return;
|
||||
|
||||
// FIXME: This should probably be handled by StyleSheet::set_owner_node().
|
||||
m_associated_css_style_sheet = JS::make_handle(sheet);
|
||||
m_associated_css_style_sheet = sheet;
|
||||
|
||||
// 6. Create a CSS style sheet with the following properties...
|
||||
create_a_css_style_sheet(
|
||||
|
@ -150,14 +158,14 @@ void HTMLStyleElement::update_a_style_block()
|
|||
CSS::CSSStyleSheet* HTMLStyleElement::sheet()
|
||||
{
|
||||
// The sheet attribute must return the associated CSS style sheet for the node or null if there is no associated CSS style sheet.
|
||||
return m_associated_css_style_sheet.cell();
|
||||
return m_associated_css_style_sheet;
|
||||
}
|
||||
|
||||
// https://www.w3.org/TR/cssom/#dom-linkstyle-sheet
|
||||
CSS::CSSStyleSheet const* HTMLStyleElement::sheet() const
|
||||
{
|
||||
// The sheet attribute must return the associated CSS style sheet for the node or null if there is no associated CSS style sheet.
|
||||
return m_associated_css_style_sheet.cell();
|
||||
return m_associated_css_style_sheet;
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue