AbortSignal.h 3.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. /*
  2. * Copyright (c) 2021, Luke Wilde <lukew@serenityos.org>
  3. * Copyright (c) 2024, Tim Ledbetter <timledbetter@gmail.com>
  4. *
  5. * SPDX-License-Identifier: BSD-2-Clause
  6. */
  7. #pragma once
  8. #include <AK/RefCounted.h>
  9. #include <AK/Weakable.h>
  10. #include <LibJS/Heap/HeapFunction.h>
  11. #include <LibWeb/DOM/EventTarget.h>
  12. #include <LibWeb/Forward.h>
  13. #include <LibWeb/WebIDL/Types.h>
  14. namespace Web::DOM {
  15. // https://dom.spec.whatwg.org/#abortsignal
  16. class AbortSignal final : public EventTarget {
  17. WEB_PLATFORM_OBJECT(AbortSignal, EventTarget);
  18. JS_DECLARE_ALLOCATOR(AbortSignal);
  19. public:
  20. static WebIDL::ExceptionOr<JS::NonnullGCPtr<AbortSignal>> construct_impl(JS::Realm&);
  21. virtual ~AbortSignal() override = default;
  22. void add_abort_algorithm(Function<void()>);
  23. // https://dom.spec.whatwg.org/#dom-abortsignal-aborted
  24. // An AbortSignal object is aborted when its abort reason is not undefined.
  25. bool aborted() const { return !m_abort_reason.is_undefined(); }
  26. void signal_abort(JS::Value reason);
  27. void set_onabort(WebIDL::CallbackType*);
  28. WebIDL::CallbackType* onabort();
  29. // https://dom.spec.whatwg.org/#dom-abortsignal-reason
  30. JS::Value reason() const { return m_abort_reason; }
  31. void set_reason(JS::Value reason) { m_abort_reason = reason; }
  32. JS::ThrowCompletionOr<void> throw_if_aborted() const;
  33. void follow(JS::NonnullGCPtr<AbortSignal> parent_signal);
  34. static WebIDL::ExceptionOr<JS::NonnullGCPtr<AbortSignal>> abort(JS::VM&, JS::Value reason);
  35. static WebIDL::ExceptionOr<JS::NonnullGCPtr<AbortSignal>> timeout(JS::VM&, Web::WebIDL::UnsignedLongLong milliseconds);
  36. static WebIDL::ExceptionOr<JS::NonnullGCPtr<AbortSignal>> any(JS::VM&, JS::Value signals);
  37. private:
  38. explicit AbortSignal(JS::Realm&);
  39. virtual void initialize(JS::Realm&) override;
  40. virtual void visit_edges(JS::Cell::Visitor&) override;
  41. static WebIDL::ExceptionOr<JS::NonnullGCPtr<AbortSignal>> create_dependent_abort_signal(JS::Realm&, Vector<JS::Handle<AbortSignal>> const&);
  42. bool dependent() const { return m_dependent; }
  43. void set_dependent(bool dependent) { m_dependent = dependent; }
  44. Vector<JS::GCPtr<AbortSignal>> source_signals() const { return m_source_signals; }
  45. void append_source_signal(JS::GCPtr<AbortSignal> source_signal) { m_source_signals.append(source_signal); }
  46. void append_dependent_signal(JS::GCPtr<AbortSignal> dependent_signal) { m_dependent_signals.append(dependent_signal); }
  47. // https://dom.spec.whatwg.org/#abortsignal-abort-reason
  48. // An AbortSignal object has an associated abort reason, which is a JavaScript value. It is undefined unless specified otherwise.
  49. JS::Value m_abort_reason { JS::js_undefined() };
  50. // https://dom.spec.whatwg.org/#abortsignal-abort-algorithms
  51. // FIXME: This should be a set.
  52. Vector<JS::NonnullGCPtr<JS::HeapFunction<void()>>> m_abort_algorithms;
  53. // https://dom.spec.whatwg.org/#abortsignal-source-signals
  54. // An AbortSignal object has associated source signals (a weak set of AbortSignal objects that the object is dependent on for its aborted state), which is initially empty.
  55. Vector<JS::GCPtr<AbortSignal>> m_source_signals;
  56. // https://dom.spec.whatwg.org/#abortsignal-dependent-signals
  57. // An AbortSignal object has associated dependent signals (a weak set of AbortSignal objects that are dependent on the object for their aborted state), which is initially empty.
  58. Vector<JS::GCPtr<AbortSignal>> m_dependent_signals;
  59. // https://dom.spec.whatwg.org/#abortsignal-dependent
  60. // An AbortSignal object has a dependent (a boolean), which is initially false.
  61. bool m_dependent { false };
  62. };
  63. }