IdleDeadline.cpp 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. /*
  2. * Copyright (c) 2021, Andreas Kling <kling@serenityos.org>
  3. * Copyright (c) 2022, the SerenityOS developers.
  4. *
  5. * SPDX-License-Identifier: BSD-2-Clause
  6. */
  7. #include <LibWeb/HTML/EventLoop/EventLoop.h>
  8. #include <LibWeb/HTML/Window.h>
  9. #include <LibWeb/HighResolutionTime/TimeOrigin.h>
  10. #include <LibWeb/RequestIdleCallback/IdleDeadline.h>
  11. namespace Web::RequestIdleCallback {
  12. JS::NonnullGCPtr<IdleDeadline> IdleDeadline::create(JS::Realm& realm, bool did_timeout)
  13. {
  14. return realm.heap().allocate<IdleDeadline>(realm, realm, did_timeout);
  15. }
  16. IdleDeadline::IdleDeadline(JS::Realm& realm, bool did_timeout)
  17. : PlatformObject(realm)
  18. , m_did_timeout(did_timeout)
  19. {
  20. }
  21. void IdleDeadline::initialize(JS::Realm& realm)
  22. {
  23. Base::initialize(realm);
  24. set_prototype(&Bindings::ensure_web_prototype<Bindings::IdleDeadlinePrototype>(realm, "IdleDeadline"));
  25. }
  26. IdleDeadline::~IdleDeadline() = default;
  27. // https://w3c.github.io/requestidlecallback/#dom-idledeadline-timeremaining
  28. double IdleDeadline::time_remaining() const
  29. {
  30. auto const& event_loop = HTML::main_thread_event_loop();
  31. // 1. Let now be a DOMHighResTimeStamp representing current high resolution time in milliseconds.
  32. auto now = HighResolutionTime::unsafe_shared_current_time();
  33. // 2. Let deadline be the result of calling IdleDeadline's get deadline time algorithm.
  34. auto deadline = event_loop.compute_deadline();
  35. // 3. Let timeRemaining be deadline - now.
  36. auto time_remaining = deadline - now;
  37. // 4. If timeRemaining is negative, set it to 0.
  38. if (time_remaining < 0)
  39. time_remaining = 0;
  40. // 5. Return timeRemaining.
  41. // NOTE: coarsening to milliseconds
  42. return ceil(time_remaining);
  43. }
  44. }