diff options
author | Andreas Kling <kling@serenityos.org> | 2022-08-28 13:42:07 +0200 |
---|---|---|
committer | Andreas Kling <kling@serenityos.org> | 2022-09-06 00:27:09 +0200 |
commit | 6f433c86564c24d47d520cb5bdcc2209d724ac96 (patch) | |
tree | 886a2f727782e466e99c61c628637872c1b7403f /Userland/Libraries/LibWeb/HTML/HTMLHtmlElement.h | |
parent | bb547ce1c4251e3689287eac845593398a379ca5 (diff) | |
download | serenity-6f433c86564c24d47d520cb5bdcc2209d724ac96.zip |
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.
Diffstat (limited to 'Userland/Libraries/LibWeb/HTML/HTMLHtmlElement.h')
-rw-r--r-- | Userland/Libraries/LibWeb/HTML/HTMLHtmlElement.h | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/Userland/Libraries/LibWeb/HTML/HTMLHtmlElement.h b/Userland/Libraries/LibWeb/HTML/HTMLHtmlElement.h index 1222355040..0f8c6b3c5f 100644 --- a/Userland/Libraries/LibWeb/HTML/HTMLHtmlElement.h +++ b/Userland/Libraries/LibWeb/HTML/HTMLHtmlElement.h @@ -11,15 +11,16 @@ namespace Web::HTML { class HTMLHtmlElement final : public HTMLElement { -public: - using WrapperType = Bindings::HTMLHtmlElementWrapper; + WEB_PLATFORM_OBJECT(HTMLHtmlElement, HTMLElement); - HTMLHtmlElement(DOM::Document&, DOM::QualifiedName); +public: virtual ~HTMLHtmlElement() override; bool should_use_body_background_properties() const; private: + HTMLHtmlElement(DOM::Document&, DOM::QualifiedName); + virtual bool is_html_html_element() const override { return true; } }; @@ -29,3 +30,5 @@ namespace Web::DOM { template<> inline bool Node::fast_is<HTML::HTMLHtmlElement>() const { return is_html_html_element(); } } + +WRAPPER_HACK(HTMLHtmlElement, Web::HTML) |