mirror of
https://github.com/RGBCube/serenity
synced 2025-10-24 05:32:31 +00:00

These classes only needed Window to get at its realm. Pass a realm directly to construct DOM and WebIDL classes. This change importantly removes the guarantee that a Document will always have a non-null Window object. Only Documents created by a BrowsingContext will have a non-null Window object. Documents created by for example, DocumentFragment, will not have a Window (soon). This incremental commit leaves some workarounds in place to keep other parts of the code building.
53 lines
1.5 KiB
C++
53 lines
1.5 KiB
C++
/*
|
||
* Copyright (c) 2021, Luke Wilde <lukew@serenityos.org>
|
||
* Copyright (c) 2022, Andreas Kling <kling@serenityos.org>
|
||
*
|
||
* SPDX-License-Identifier: BSD-2-Clause
|
||
*/
|
||
|
||
#include <LibJS/Runtime/Realm.h>
|
||
#include <LibWeb/Bindings/Intrinsics.h>
|
||
#include <LibWeb/DOM/CustomEvent.h>
|
||
|
||
namespace Web::DOM {
|
||
|
||
CustomEvent* CustomEvent::create(JS::Realm& realm, FlyString const& event_name, CustomEventInit const& event_init)
|
||
{
|
||
return realm.heap().allocate<CustomEvent>(realm, realm, event_name, event_init);
|
||
}
|
||
|
||
CustomEvent* CustomEvent::construct_impl(JS::Realm& realm, FlyString const& event_name, CustomEventInit const& event_init)
|
||
{
|
||
return create(realm, event_name, event_init);
|
||
}
|
||
|
||
CustomEvent::CustomEvent(JS::Realm& realm, FlyString const& event_name, CustomEventInit const& event_init)
|
||
: Event(realm, event_name, event_init)
|
||
, m_detail(event_init.detail)
|
||
{
|
||
set_prototype(&Bindings::cached_web_prototype(realm, "CustomEvent"));
|
||
}
|
||
|
||
CustomEvent::~CustomEvent() = default;
|
||
|
||
void CustomEvent::visit_edges(JS::Cell::Visitor& visitor)
|
||
{
|
||
Base::visit_edges(visitor);
|
||
visitor.visit(m_detail);
|
||
}
|
||
|
||
// https://dom.spec.whatwg.org/#dom-customevent-initcustomevent
|
||
void CustomEvent::init_custom_event(String const& type, bool bubbles, bool cancelable, JS::Value detail)
|
||
{
|
||
// 1. If this’s dispatch flag is set, then return.
|
||
if (dispatched())
|
||
return;
|
||
|
||
// 2. Initialize this with type, bubbles, and cancelable.
|
||
initialize_event(type, bubbles, cancelable);
|
||
|
||
// 3. Set this’s detail attribute to detail.
|
||
m_detail = detail;
|
||
}
|
||
|
||
}
|