/* * 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 RefCounted , public Weakable , public EventTarget , public Bindings::Wrappable { public: using WrapperType = Bindings::AbortSignalWrapper; using RefCounted::ref; using RefCounted::unref; static NonnullRefPtr create(Document& document) { return adopt_ref(*new AbortSignal(document)); } static NonnullRefPtr create_with_global_object(Bindings::WindowObject& window_object) { return AbortSignal::create(window_object.impl().associated_document()); } virtual ~AbortSignal() override; 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(HTML::EventHandler); HTML::EventHandler onabort(); // https://dom.spec.whatwg.org/#dom-abortsignal-reason JS::Value reason() const { return m_abort_reason; } JS::ThrowCompletionOr throw_if_aborted() const; void visit_edges(JS::Cell::Visitor&); // ^EventTarget virtual void ref_event_target() override { ref(); } virtual void unref_event_target() override { unref(); } virtual JS::Object* create_wrapper(JS::GlobalObject&) override; private: AbortSignal(Document& document); // 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; }; }