/* * 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() { return adopt_ref(*new AbortSignal()); } static NonnullRefPtr create_with_global_object(Bindings::WindowObject&) { return AbortSignal::create(); } 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(Optional); 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; 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(); // 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; }; }