TaskQueue.h 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. /*
  2. * Copyright (c) 2021-2024, Andreas Kling <andreas@ladybird.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <AK/Queue.h>
  8. #include <LibJS/Heap/Cell.h>
  9. #include <LibWeb/HTML/EventLoop/Task.h>
  10. namespace Web::HTML {
  11. class TaskQueue : public JS::Cell {
  12. GC_CELL(TaskQueue, JS::Cell);
  13. GC_DECLARE_ALLOCATOR(TaskQueue);
  14. public:
  15. explicit TaskQueue(HTML::EventLoop&);
  16. virtual ~TaskQueue() override;
  17. bool is_empty() const { return m_tasks.is_empty(); }
  18. bool has_runnable_tasks() const;
  19. bool has_rendering_tasks() const;
  20. void add(GC::Ref<HTML::Task>);
  21. GC::Ptr<HTML::Task> take_first_runnable();
  22. void enqueue(GC::Ref<HTML::Task> task) { add(task); }
  23. GC::Ptr<HTML::Task> dequeue()
  24. {
  25. if (m_tasks.is_empty())
  26. return {};
  27. return m_tasks.take_first();
  28. }
  29. void remove_tasks_matching(Function<bool(HTML::Task const&)>);
  30. GC::RootVector<GC::Ref<Task>> take_tasks_matching(Function<bool(HTML::Task const&)>);
  31. Task const* last_added_task() const;
  32. private:
  33. virtual void visit_edges(Visitor&) override;
  34. GC::Ref<HTML::EventLoop> m_event_loop;
  35. Vector<GC::Ref<HTML::Task>> m_tasks;
  36. };
  37. }