/* * Copyright (c) 2021-2022, Andreas Kling * * SPDX-License-Identifier: BSD-2-Clause */ #pragma once #include #include #include #include #include namespace Web::HTML { class EventHandler final : public JS::Cell { JS_CELL(EventHandler, JS::Cell); JS_DECLARE_ALLOCATOR(EventHandler); public: explicit EventHandler(ByteString); explicit EventHandler(WebIDL::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> value; // https://html.spec.whatwg.org/multipage/webappapis.html#event-handler-listener JS::GCPtr listener; private: virtual void visit_edges(Cell::Visitor&) override; }; }