12345678910111213141516171819202122232425262728293031323334353637383940414243 |
- /*
- * Copyright (c) 2021, Andreas Kling <kling@serenityos.org>
- * Copyright (c) 2022, the SerenityOS developers.
- *
- * SPDX-License-Identifier: BSD-2-Clause
- */
- #include <LibWeb/HTML/EventLoop/EventLoop.h>
- #include <LibWeb/RequestIdleCallback/IdleDeadline.h>
- namespace Web::RequestIdleCallback {
- NonnullRefPtr<IdleDeadline> IdleDeadline::create(bool did_timeout)
- {
- return adopt_ref(*new IdleDeadline(did_timeout));
- }
- IdleDeadline::IdleDeadline(bool did_timeout)
- : m_did_timeout(did_timeout)
- {
- }
- IdleDeadline::~IdleDeadline() = default;
- // https://w3c.github.io/requestidlecallback/#dom-idledeadline-timeremaining
- double IdleDeadline::time_remaining() const
- {
- auto const& event_loop = HTML::main_thread_event_loop();
- // 1. Let now be a DOMHighResTimeStamp representing current high resolution time in milliseconds.
- auto now = event_loop.unsafe_shared_current_time();
- // 2. Let deadline be the result of calling IdleDeadline's get deadline time algorithm.
- auto deadline = event_loop.compute_deadline();
- // 3. Let timeRemaining be deadline - now.
- auto time_remaining = deadline - now;
- // 4. If timeRemaining is negative, set it to 0.
- if (time_remaining < 0)
- time_remaining = 0;
- // 5. Return timeRemaining.
- // NOTE: coarsening to milliseconds
- return ceil(time_remaining);
- }
- }
|