forked from mirrors/gecko-dev
The rustup is needed for https://github.com/rust-lang/rust/pull/40039. Source-Repo: https://github.com/servo/servo Source-Revision: a204c4176dcccdad8ec99d74055c66794c3f64ba --HG-- rename : servo/components/domobject_derive/Cargo.toml => servo/components/dom_struct/Cargo.toml extra : subtree_source : https%3A//hg.mozilla.org/projects/converted-servo-linear extra : subtree_revision : 2cad140c3d6b99837f0bd15a6f3ccba0f353e049
58 lines
2.2 KiB
Rust
58 lines
2.2 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 http://mozilla.org/MPL/2.0/. */
|
|
|
|
use dom::bindings::codegen::Bindings::PerformanceBinding;
|
|
use dom::bindings::codegen::Bindings::PerformanceBinding::PerformanceMethods;
|
|
use dom::bindings::js::{JS, Root};
|
|
use dom::bindings::num::Finite;
|
|
use dom::bindings::reflector::{Reflector, reflect_dom_object};
|
|
use dom::performancetiming::PerformanceTiming;
|
|
use dom::window::Window;
|
|
use dom_struct::dom_struct;
|
|
use time;
|
|
|
|
pub type DOMHighResTimeStamp = Finite<f64>;
|
|
|
|
#[dom_struct]
|
|
pub struct Performance {
|
|
reflector_: Reflector,
|
|
timing: JS<PerformanceTiming>,
|
|
}
|
|
|
|
impl Performance {
|
|
fn new_inherited(window: &Window,
|
|
navigation_start: u64,
|
|
navigation_start_precise: f64) -> Performance {
|
|
Performance {
|
|
reflector_: Reflector::new(),
|
|
timing: JS::from_ref(&*PerformanceTiming::new(window,
|
|
navigation_start,
|
|
navigation_start_precise)),
|
|
}
|
|
}
|
|
|
|
pub fn new(window: &Window,
|
|
navigation_start: u64,
|
|
navigation_start_precise: f64) -> Root<Performance> {
|
|
reflect_dom_object(box Performance::new_inherited(window,
|
|
navigation_start,
|
|
navigation_start_precise),
|
|
window,
|
|
PerformanceBinding::Wrap)
|
|
}
|
|
}
|
|
|
|
impl PerformanceMethods for Performance {
|
|
// https://dvcs.w3.org/hg/webperf/raw-file/tip/specs/NavigationTiming/Overview.html#performance-timing-attribute
|
|
fn Timing(&self) -> Root<PerformanceTiming> {
|
|
Root::from_ref(&*self.timing)
|
|
}
|
|
|
|
// https://dvcs.w3.org/hg/webperf/raw-file/tip/specs/HighResolutionTime/Overview.html#dom-performance-now
|
|
fn Now(&self) -> DOMHighResTimeStamp {
|
|
let nav_start = self.timing.navigation_start_precise();
|
|
let now = (time::precise_time_ns() as f64 - nav_start) / 1000000 as f64;
|
|
Finite::wrap(now)
|
|
}
|
|
}
|