forked from mirrors/gecko-dev
<!-- Please describe your changes on the following line: --> Added time to interactive metrics and refactored metrics/lib I need to write tests, but wanted to submit the PR for review --- <!-- Thank you for contributing to Servo! Please replace each `[ ]` by `[X]` when the step is complete, and replace `__` with appropriate data: --> - [ ] `./mach build -d` does not report any errors - [ ] `./mach test-tidy` does not report any errors - [ ] These changes fix #__ (github issue number if applicable). <!-- Either: --> - [ ] There are tests for these changes OR - [ ] These changes do not require tests because _____ <!-- Also, please make sure that "Allow edits from maintainers" checkbox is checked, so that we can help you if you get stuck somewhere along the way.--> <!-- Pull requests that do not address these steps are welcome, but they will require additional verification as part of the review process. --> Source-Repo: https://github.com/servo/servo Source-Revision: e438b094f675469b8bdbb1ab4ff84c374fc399d4 --HG-- extra : subtree_source : https%3A//hg.mozilla.org/projects/converted-servo-linear extra : subtree_revision : bac1798200377932a85607154d5baa4f451b30e6
62 lines
2 KiB
Rust
62 lines
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/. */
|
|
|
|
// XXX The spec says that the performance timeline task source should be
|
|
// a low priority task and it should be processed during idle periods.
|
|
// We are currently treating this task queue as a normal priority queue.
|
|
|
|
use dom::bindings::refcounted::Trusted;
|
|
use dom::globalscope::GlobalScope;
|
|
use msg::constellation_msg::PipelineId;
|
|
use script_runtime::{CommonScriptMsg, ScriptChan, ScriptThreadEventCategory};
|
|
use std::fmt;
|
|
use std::result::Result;
|
|
use task::{TaskCanceller, TaskOnce};
|
|
use task_source::TaskSource;
|
|
|
|
#[derive(JSTraceable)]
|
|
pub struct PerformanceTimelineTaskSource(pub Box<ScriptChan + Send + 'static>, pub PipelineId);
|
|
|
|
impl Clone for PerformanceTimelineTaskSource {
|
|
fn clone(&self) -> PerformanceTimelineTaskSource {
|
|
PerformanceTimelineTaskSource(self.0.clone(), self.1.clone())
|
|
}
|
|
}
|
|
|
|
impl fmt::Debug for PerformanceTimelineTaskSource {
|
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
|
write!(f, "PerformanceTimelineTaskSource(...)")
|
|
}
|
|
}
|
|
|
|
impl TaskSource for PerformanceTimelineTaskSource {
|
|
fn queue_with_canceller<T>(
|
|
&self,
|
|
task: T,
|
|
canceller: &TaskCanceller,
|
|
) -> Result<(), ()>
|
|
where
|
|
T: TaskOnce + 'static,
|
|
{
|
|
let msg = CommonScriptMsg::Task(
|
|
ScriptThreadEventCategory::PerformanceTimelineTask,
|
|
Box::new(canceller.wrap_task(task)),
|
|
Some(self.1)
|
|
);
|
|
self.0.send(msg).map_err(|_| ())
|
|
}
|
|
}
|
|
|
|
impl PerformanceTimelineTaskSource {
|
|
pub fn queue_notification(&self, global: &GlobalScope) {
|
|
let owner = Trusted::new(&*global.performance());
|
|
// FIXME(nox): Why are errors silenced here?
|
|
let _ = self.queue(
|
|
task!(notify_performance_observers: move || {
|
|
owner.root().notify_observers();
|
|
}),
|
|
global,
|
|
);
|
|
}
|
|
}
|