FetchTimingInfo.cpp 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637
  1. /*
  2. * Copyright (c) 2022, Linus Groh <linusg@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include <LibJS/Heap/Heap.h>
  7. #include <LibJS/Runtime/VM.h>
  8. #include <LibWeb/Fetch/Infrastructure/FetchTimingInfo.h>
  9. namespace Web::Fetch::Infrastructure {
  10. FetchTimingInfo::FetchTimingInfo() = default;
  11. JS::NonnullGCPtr<FetchTimingInfo> FetchTimingInfo::create(JS::VM& vm)
  12. {
  13. return vm.heap().allocate_without_realm<FetchTimingInfo>();
  14. }
  15. void FetchTimingInfo::visit_edges(JS::Cell::Visitor& visitor)
  16. {
  17. Base::visit_edges(visitor);
  18. visitor.visit(m_final_connection_timing_info);
  19. }
  20. // https://fetch.spec.whatwg.org/#create-an-opaque-timing-info
  21. JS::NonnullGCPtr<FetchTimingInfo> create_opaque_timing_info(JS::VM& vm, FetchTimingInfo const& timing_info)
  22. {
  23. // To create an opaque timing info, given a fetch timing info timingInfo, return a new fetch timing info whose
  24. // start time and post-redirect start time are timingInfo’s start time.
  25. auto new_timing_info = FetchTimingInfo::create(vm);
  26. new_timing_info->set_start_time(timing_info.start_time());
  27. new_timing_info->set_post_redirect_start_time(timing_info.start_time());
  28. return new_timing_info;
  29. }
  30. }