
This was resulting in a whole lot of rebuilding whenever a new IDL interface was added. Instead, just directly include the prototype in every C++ file which needs it. While we only really need a forward declaration in each cpp file; including the full prototype header (which itself only includes LibJS/Object.h, which is already transitively brought in by PlatformObject) - it seems like a small price to pay compared to what feels like a full rebuild of LibWeb whenever a new IDL file is added. Given all of these includes are only needed for the ::initialize method, there is probably a smart way of avoiding this problem altogether. I've considered both using some macro trickery or generating these functions somehow instead.
50 lines
1.3 KiB
C++
50 lines
1.3 KiB
C++
/*
|
||
* Copyright (c) 2021, Luke Wilde <lukew@serenityos.org>
|
||
*
|
||
* SPDX-License-Identifier: BSD-2-Clause
|
||
*/
|
||
|
||
#include <LibWeb/Bindings/AbortControllerPrototype.h>
|
||
#include <LibWeb/Bindings/Intrinsics.h>
|
||
#include <LibWeb/DOM/AbortController.h>
|
||
#include <LibWeb/DOM/AbortSignal.h>
|
||
|
||
namespace Web::DOM {
|
||
|
||
JS_DEFINE_ALLOCATOR(AbortController);
|
||
|
||
WebIDL::ExceptionOr<JS::NonnullGCPtr<AbortController>> AbortController::construct_impl(JS::Realm& realm)
|
||
{
|
||
auto signal = TRY(AbortSignal::construct_impl(realm));
|
||
return realm.heap().allocate<AbortController>(realm, realm, move(signal));
|
||
}
|
||
|
||
// https://dom.spec.whatwg.org/#dom-abortcontroller-abortcontroller
|
||
AbortController::AbortController(JS::Realm& realm, JS::NonnullGCPtr<AbortSignal> signal)
|
||
: PlatformObject(realm)
|
||
, m_signal(move(signal))
|
||
{
|
||
}
|
||
|
||
AbortController::~AbortController() = default;
|
||
|
||
void AbortController::initialize(JS::Realm& realm)
|
||
{
|
||
Base::initialize(realm);
|
||
WEB_SET_PROTOTYPE_FOR_INTERFACE(AbortController);
|
||
}
|
||
|
||
void AbortController::visit_edges(Cell::Visitor& visitor)
|
||
{
|
||
Base::visit_edges(visitor);
|
||
visitor.visit(m_signal);
|
||
}
|
||
|
||
// https://dom.spec.whatwg.org/#dom-abortcontroller-abort
|
||
void AbortController::abort(JS::Value reason)
|
||
{
|
||
// The abort(reason) method steps are to signal abort on this’s signal with reason if it is given.
|
||
m_signal->signal_abort(reason);
|
||
}
|
||
|
||
}
|