/* * Copyright (c) 2021, Luke Wilde * * SPDX-License-Identifier: BSD-2-Clause */ #pragma once #include #include #include #include #include #include namespace Web::DOM { // https://dom.spec.whatwg.org/#abortsignal class AbortSignal final : public EventTarget { WEB_PLATFORM_OBJECT(AbortSignal, EventTarget); public: static JS::NonnullGCPtr create_with_global_object(HTML::Window&); virtual ~AbortSignal() override = default; void add_abort_algorithm(Function); // https://dom.spec.whatwg.org/#dom-abortsignal-aborted // An AbortSignal object is aborted when its abort reason is not undefined. bool aborted() const { return !m_abort_reason.is_undefined(); } void signal_abort(JS::Value reason); void set_onabort(Bindings::CallbackType*); Bindings::CallbackType* onabort(); // https://dom.spec.whatwg.org/#dom-abortsignal-reason JS::Value reason() const { return m_abort_reason; } JS::ThrowCompletionOr throw_if_aborted() const; private: explicit AbortSignal(HTML::Window&); virtual void visit_edges(JS::Cell::Visitor&) override; // https://dom.spec.whatwg.org/#abortsignal-abort-reason // An AbortSignal object has an associated abort reason, which is a JavaScript value. It is undefined unless specified otherwise. JS::Value m_abort_reason { JS::js_undefined() }; // https://dom.spec.whatwg.org/#abortsignal-abort-algorithms // FIXME: This should be a set. Vector> m_abort_algorithms; }; } WRAPPER_HACK(AbortSignal, Web::DOM)