Skip to content

Commit

Permalink
Update Event's timestamp
Browse files Browse the repository at this point in the history
  • Loading branch information
georgeroman committed Mar 26, 2019
1 parent c9b5b8f commit e63de4d
Show file tree
Hide file tree
Showing 4 changed files with 16 additions and 15 deletions.
15 changes: 11 additions & 4 deletions components/script/dom/event.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,11 @@ use crate::dom::bindings::callback::ExceptionHandling;
use crate::dom::bindings::cell::DomRefCell;
use crate::dom::bindings::codegen::Bindings::EventBinding;
use crate::dom::bindings::codegen::Bindings::EventBinding::{EventConstants, EventMethods};
use crate::dom::bindings::codegen::Bindings::PerformanceBinding::DOMHighResTimeStamp;
use crate::dom::bindings::codegen::Bindings::PerformanceBinding::PerformanceBinding::PerformanceMethods;
use crate::dom::bindings::error::Fallible;
use crate::dom::bindings::inheritance::Castable;
use crate::dom::bindings::num::Finite;
use crate::dom::bindings::refcounted::Trusted;
use crate::dom::bindings::reflector::{reflect_dom_object, DomObject, Reflector};
use crate::dom::bindings::root::{DomRoot, DomSlice, MutNullableDom};
Expand All @@ -21,6 +24,7 @@ use crate::dom::window::Window;
use crate::task::TaskOnce;
use devtools_traits::{TimelineMarker, TimelineMarkerType};
use dom_struct::dom_struct;
use metrics::ToMs;
use servo_atoms::Atom;
use std::cell::Cell;
use std::default::Default;
Expand All @@ -40,7 +44,7 @@ pub struct Event {
trusted: Cell<bool>,
dispatching: Cell<bool>,
initialized: Cell<bool>,
timestamp: u64,
precise_time_ns: u64,
}

impl Event {
Expand All @@ -59,7 +63,7 @@ impl Event {
trusted: Cell::new(false),
dispatching: Cell::new(false),
initialized: Cell::new(false),
timestamp: time::get_time().sec as u64,
precise_time_ns: time::precise_time_ns(),
}
}

Expand Down Expand Up @@ -322,8 +326,11 @@ impl EventMethods for Event {
}

// https://dom.spec.whatwg.org/#dom-event-timestamp
fn TimeStamp(&self) -> u64 {
self.timestamp
fn TimeStamp(&self) -> DOMHighResTimeStamp {
Finite::wrap(
(self.precise_time_ns - (*self.global().performance().TimeOrigin()).round() as u64)
.to_ms(),
)
}

// https://dom.spec.whatwg.org/#dom-event-initevent
Expand Down
2 changes: 1 addition & 1 deletion components/script/dom/webidls/Event.webidl
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ interface Event {
[Unforgeable]
readonly attribute boolean isTrusted;
[Constant]
readonly attribute DOMTimeStamp timeStamp;
readonly attribute DOMHighResTimeStamp timeStamp;

void initEvent(DOMString type, optional boolean bubbles = false, optional boolean cancelable = false);
};
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,18 +3,9 @@
[Untitled]
expected: FAIL

[Constructed MouseEvent timestamp should be high resolution and have the same time origin as performance.now()]
expected: FAIL

[Constructed KeyboardEvent timestamp should be high resolution and have the same time origin as performance.now()]
expected: FAIL

[Constructed WheelEvent timestamp should be high resolution and have the same time origin as performance.now()]
expected: FAIL

[Constructed GamepadEvent timestamp should be high resolution and have the same time origin as performance.now()]
expected: FAIL

[Constructed FocusEvent timestamp should be high resolution and have the same time origin as performance.now()]
expected: FAIL

Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
[Event-timestamp-safe-resolution.html]
type: testharness
expected: TIMEOUT

[Event timestamp should not have a resolution better than 5 microseconds]
expected: FAIL

0 comments on commit e63de4d

Please sign in to comment.