summaryrefslogtreecommitdiff
path: root/Userland/Libraries/LibWeb/HTML/EventHandler.h
diff options
context:
space:
mode:
authorAndreas Kling <kling@serenityos.org>2022-08-08 14:12:01 +0200
committerAndreas Kling <kling@serenityos.org>2022-09-06 00:27:09 +0200
commit8cda70c892c029478e9b87c909b752e000050b38 (patch)
tree6b0686ffeb8c79cf17887cd252bde228b49ab2fb /Userland/Libraries/LibWeb/HTML/EventHandler.h
parent967a3e5a45af23f7922cffab9d77c0870ecbf3f2 (diff)
downloadserenity-8cda70c892c029478e9b87c909b752e000050b38.zip
LibWeb: Move event listeners, handlers and callbacks to the GC heap
This patch moves the following things to being GC-allocated: - Bindings::CallbackType - HTML::EventHandler - DOM::IDLEventListener - DOM::DOMEventListener - DOM::NodeFilter Note that we only use PlatformObject for things that might be exposed to web content. Anything that is only used internally inherits directly from JS::Cell instead, making them a bit more lightweight.
Diffstat (limited to 'Userland/Libraries/LibWeb/HTML/EventHandler.h')
-rw-r--r--Userland/Libraries/LibWeb/HTML/EventHandler.h28
1 files changed, 12 insertions, 16 deletions
diff --git a/Userland/Libraries/LibWeb/HTML/EventHandler.h b/Userland/Libraries/LibWeb/HTML/EventHandler.h
index 888c6b8bb8..a7be161c6e 100644
--- a/Userland/Libraries/LibWeb/HTML/EventHandler.h
+++ b/Userland/Libraries/LibWeb/HTML/EventHandler.h
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 2021, Andreas Kling <kling@serenityos.org>
+ * Copyright (c) 2021-2022, Andreas Kling <kling@serenityos.org>
*
* SPDX-License-Identifier: BSD-2-Clause
*/
@@ -8,33 +8,29 @@
#include <AK/String.h>
#include <AK/Variant.h>
-#include <LibJS/Heap/Handle.h>
-#include <LibJS/Runtime/FunctionObject.h>
+#include <LibJS/Heap/Cell.h>
#include <LibWeb/Bindings/CallbackType.h>
-#include <LibWeb/DOM/DOMEventListener.h>
namespace Web::HTML {
-struct EventHandler {
- EventHandler(String s)
- : value(move(s))
- {
- }
-
- EventHandler(Bindings::CallbackType c)
- : value(move(c))
- {
- }
+class EventHandler final : public JS::Cell {
+public:
+ explicit EventHandler(String);
+ explicit EventHandler(Bindings::CallbackType&);
// Either uncompiled source code or a callback.
// https://html.spec.whatwg.org/multipage/webappapis.html#event-handler-value
// NOTE: This does not contain Empty as part of the optimization of not allocating all event handler attributes up front.
// FIXME: The string should actually be an "internal raw uncompiled handler" struct. This struct is just the uncompiled source code plus a source location for reporting parse errors.
// https://html.spec.whatwg.org/multipage/webappapis.html#internal-raw-uncompiled-handler
- Variant<String, Bindings::CallbackType> value;
+ Variant<String, Bindings::CallbackType*> value;
// https://html.spec.whatwg.org/multipage/webappapis.html#event-handler-listener
- RefPtr<DOM::DOMEventListener> listener;
+ DOM::DOMEventListener* listener { nullptr };
+
+private:
+ virtual StringView class_name() const override { return "EventHandler"sv; }
+ virtual void visit_edges(Cell::Visitor&) override;
};
}