mirror of
https://github.com/servo/servo.git
synced 2025-06-06 16:45:39 +00:00
* script: Restrict reexport visibility of DOM types. Signed-off-by: Josh Matthews <josh@joshmatthews.net> * script: Mass pub->pub(crate) conversion. Signed-off-by: Josh Matthews <josh@joshmatthews.net> * script: Hide existing dead code warnings. Signed-off-by: Josh Matthews <josh@joshmatthews.net> * Formatting. Signed-off-by: Josh Matthews <josh@joshmatthews.net> * Fix clippy warnings. Signed-off-by: Josh Matthews <josh@joshmatthews.net> * Formatting. Signed-off-by: Josh Matthews <josh@joshmatthews.net> * Fix unit tests. Signed-off-by: Josh Matthews <josh@joshmatthews.net> * Fix clippy. Signed-off-by: Josh Matthews <josh@joshmatthews.net> * More formatting. Signed-off-by: Josh Matthews <josh@joshmatthews.net> --------- Signed-off-by: Josh Matthews <josh@joshmatthews.net>
57 lines
1.8 KiB
Rust
57 lines
1.8 KiB
Rust
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at https://mozilla.org/MPL/2.0/. */
|
|
|
|
#![deny(missing_docs)]
|
|
|
|
//! A timeline module, used to specify an `AnimationTimeline` which determines
|
|
//! the time used for synchronizing animations in the script thread.
|
|
|
|
use std::time::{SystemTime, UNIX_EPOCH};
|
|
|
|
use jstraceable_derive::JSTraceable;
|
|
|
|
/// A `AnimationTimeline` which is used to synchronize animations during the script
|
|
/// event loop.
|
|
#[derive(Clone, Copy, Debug, JSTraceable, MallocSizeOf)]
|
|
pub(crate) struct AnimationTimeline {
|
|
current_value: f64,
|
|
}
|
|
|
|
impl AnimationTimeline {
|
|
/// Creates a new "normal" timeline, i.e., a "Current" mode timer.
|
|
#[inline]
|
|
pub(crate) fn new() -> Self {
|
|
Self {
|
|
current_value: SystemTime::now()
|
|
.duration_since(UNIX_EPOCH)
|
|
.unwrap_or_default()
|
|
.as_secs_f64(),
|
|
}
|
|
}
|
|
|
|
/// Creates a new "test mode" timeline, with initial time 0.
|
|
#[inline]
|
|
pub(crate) fn new_for_testing() -> Self {
|
|
Self { current_value: 0. }
|
|
}
|
|
|
|
/// Returns the current value of the timeline in seconds.
|
|
pub(crate) fn current_value(&self) -> f64 {
|
|
self.current_value
|
|
}
|
|
|
|
/// Updates the value of the `AnimationTimeline` to the current clock time.
|
|
pub(crate) fn update(&mut self) {
|
|
self.current_value = SystemTime::now()
|
|
.duration_since(UNIX_EPOCH)
|
|
.unwrap_or_default()
|
|
.as_secs_f64();
|
|
}
|
|
|
|
/// Increments the current value of the timeline by a specific number of seconds.
|
|
/// This is used for testing.
|
|
pub(crate) fn advance_specific(&mut self, by: f64) {
|
|
self.current_value += by;
|
|
}
|
|
}
|