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/HTMLOptionElement.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/HTMLOptionElement.h')
-rw-r--r-- | Userland/Libraries/LibWeb/HTML/HTMLOptionElement.h | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/Userland/Libraries/LibWeb/HTML/HTMLOptionElement.h b/Userland/Libraries/LibWeb/HTML/HTMLOptionElement.h index 8b83003ced..79aade13c3 100644 --- a/Userland/Libraries/LibWeb/HTML/HTMLOptionElement.h +++ b/Userland/Libraries/LibWeb/HTML/HTMLOptionElement.h @@ -12,10 +12,9 @@ namespace Web::HTML { class HTMLOptionElement final : public HTMLElement { -public: - using WrapperType = Bindings::HTMLOptionElementWrapper; + WEB_PLATFORM_OBJECT(HTMLOptionElement, HTMLElement); - HTMLOptionElement(DOM::Document&, DOM::QualifiedName); +public: virtual ~HTMLOptionElement() override; bool selected() const { return m_selected; } @@ -33,6 +32,8 @@ private: friend class Bindings::OptionConstructor; friend class HTMLSelectElement; + HTMLOptionElement(DOM::Document&, DOM::QualifiedName); + void parse_attribute(FlyString const& name, String const& value) override; void did_remove_attribute(FlyString const& name) override; @@ -46,3 +47,5 @@ private: }; } + +WRAPPER_HACK(HTMLOptionElement, Web::HTML) |