AbortSignal.h 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. /*
  2. * Copyright (c) 2021, Luke Wilde <lukew@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <AK/RefCounted.h>
  8. #include <AK/Weakable.h>
  9. #include <LibWeb/DOM/EventTarget.h>
  10. #include <LibWeb/Forward.h>
  11. namespace Web::DOM {
  12. // https://dom.spec.whatwg.org/#abortsignal
  13. class AbortSignal final : public EventTarget {
  14. WEB_PLATFORM_OBJECT(AbortSignal, EventTarget);
  15. public:
  16. static WebIDL::ExceptionOr<JS::NonnullGCPtr<AbortSignal>> construct_impl(JS::Realm&);
  17. virtual ~AbortSignal() override = default;
  18. void add_abort_algorithm(JS::SafeFunction<void()>);
  19. // https://dom.spec.whatwg.org/#dom-abortsignal-aborted
  20. // An AbortSignal object is aborted when its abort reason is not undefined.
  21. bool aborted() const { return !m_abort_reason.is_undefined(); }
  22. void signal_abort(JS::Value reason);
  23. void set_onabort(WebIDL::CallbackType*);
  24. WebIDL::CallbackType* onabort();
  25. // https://dom.spec.whatwg.org/#dom-abortsignal-reason
  26. JS::Value reason() const { return m_abort_reason; }
  27. JS::ThrowCompletionOr<void> throw_if_aborted() const;
  28. void follow(JS::NonnullGCPtr<AbortSignal> parent_signal);
  29. private:
  30. explicit AbortSignal(JS::Realm&);
  31. virtual JS::ThrowCompletionOr<void> initialize(JS::Realm&) override;
  32. virtual void visit_edges(JS::Cell::Visitor&) override;
  33. // https://dom.spec.whatwg.org/#abortsignal-abort-reason
  34. // An AbortSignal object has an associated abort reason, which is a JavaScript value. It is undefined unless specified otherwise.
  35. JS::Value m_abort_reason { JS::js_undefined() };
  36. // https://dom.spec.whatwg.org/#abortsignal-abort-algorithms
  37. // FIXME: This should be a set.
  38. Vector<JS::SafeFunction<void()>> m_abort_algorithms;
  39. };
  40. }