AbortSignal.h 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  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/Bindings/Wrappable.h>
  10. #include <LibWeb/DOM/EventTarget.h>
  11. #include <LibWeb/Forward.h>
  12. #include <LibWeb/HTML/Window.h>
  13. namespace Web::DOM {
  14. // https://dom.spec.whatwg.org/#abortsignal
  15. class AbortSignal final
  16. : public RefCounted<AbortSignal>
  17. , public Weakable<AbortSignal>
  18. , public EventTarget
  19. , public Bindings::Wrappable {
  20. public:
  21. using WrapperType = Bindings::AbortSignalWrapper;
  22. using RefCounted::ref;
  23. using RefCounted::unref;
  24. static NonnullRefPtr<AbortSignal> create()
  25. {
  26. return adopt_ref(*new AbortSignal());
  27. }
  28. static NonnullRefPtr<AbortSignal> create_with_global_object(Bindings::WindowObject&)
  29. {
  30. return AbortSignal::create();
  31. }
  32. virtual ~AbortSignal() override = default;
  33. void add_abort_algorithm(Function<void()>);
  34. // https://dom.spec.whatwg.org/#dom-abortsignal-aborted
  35. // An AbortSignal object is aborted when its abort reason is not undefined.
  36. bool aborted() const { return !m_abort_reason.is_undefined(); }
  37. void signal_abort(JS::Value reason);
  38. void set_onabort(Optional<Bindings::CallbackType>);
  39. Bindings::CallbackType* onabort();
  40. // https://dom.spec.whatwg.org/#dom-abortsignal-reason
  41. JS::Value reason() const { return m_abort_reason; }
  42. JS::ThrowCompletionOr<void> throw_if_aborted() const;
  43. void visit_edges(JS::Cell::Visitor&);
  44. // ^EventTarget
  45. virtual void ref_event_target() override { ref(); }
  46. virtual void unref_event_target() override { unref(); }
  47. virtual JS::Object* create_wrapper(JS::GlobalObject&) override;
  48. private:
  49. AbortSignal();
  50. // https://dom.spec.whatwg.org/#abortsignal-abort-reason
  51. // An AbortSignal object has an associated abort reason, which is a JavaScript value. It is undefined unless specified otherwise.
  52. JS::Value m_abort_reason { JS::js_undefined() };
  53. // https://dom.spec.whatwg.org/#abortsignal-abort-algorithms
  54. // FIXME: This should be a set.
  55. Vector<Function<void()>> m_abort_algorithms;
  56. };
  57. }