Task.cpp 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738
  1. /*
  2. * Copyright (c) 2022, Linus Groh <linusg@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include <LibWeb/Fetch/Infrastructure/FetchController.h>
  7. #include <LibWeb/Fetch/Infrastructure/Task.h>
  8. #include <LibWeb/HTML/EventLoop/EventLoop.h>
  9. namespace Web::Fetch::Infrastructure {
  10. // https://fetch.spec.whatwg.org/#queue-a-fetch-task
  11. int queue_fetch_task(JS::Object& task_destination, Function<void()> algorithm)
  12. {
  13. // FIXME: 1. If taskDestination is a parallel queue, then enqueue algorithm to taskDestination.
  14. // 2. Otherwise, queue a global task on the networking task source with taskDestination and algorithm.
  15. auto& vm = task_destination.vm();
  16. return HTML::queue_global_task(HTML::Task::Source::Networking, task_destination, JS::create_heap_function(vm.heap(), move(algorithm)));
  17. }
  18. // AD-HOC: This overload allows tracking the queued task within the fetch controller so that we may cancel queued tasks
  19. // when the spec indicates that we must stop an ongoing fetch.
  20. int queue_fetch_task(JS::NonnullGCPtr<FetchController> fetch_controller, JS::Object& task_destination, Function<void()> algorithm)
  21. {
  22. auto fetch_task_id = fetch_controller->next_fetch_task_id();
  23. int event_id = queue_fetch_task(task_destination, [fetch_controller, fetch_task_id, algorithm = move(algorithm)]() {
  24. fetch_controller->fetch_task_complete(fetch_task_id);
  25. algorithm();
  26. });
  27. fetch_controller->fetch_task_queued(fetch_task_id, event_id);
  28. return event_id;
  29. }
  30. }