diff options
author | Gregory Terzian <gterzian@users.noreply.github.com> | 2019-11-17 14:37:45 +0800 |
---|---|---|
committer | Gregory Terzian <gterzian@users.noreply.github.com> | 2019-11-19 14:32:21 +0800 |
commit | 50a7111eb65155fc7a0bdb1646c4a2e0ebdd8f90 (patch) | |
tree | 503c793b58480822a9e74e064ec4876f3e74e9fe /components/script/task_source/timer.rs | |
parent | d553158e95cd5988eeb3e32310c11971c0450449 (diff) | |
download | servo-50a7111eb65155fc7a0bdb1646c4a2e0ebdd8f90.tar.gz servo-50a7111eb65155fc7a0bdb1646c4a2e0ebdd8f90.zip |
impl timer-task-source, dedicated time-out mechanism for service-worker
Diffstat (limited to 'components/script/task_source/timer.rs')
-rw-r--r-- | components/script/task_source/timer.rs | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/components/script/task_source/timer.rs b/components/script/task_source/timer.rs new file mode 100644 index 00000000000..cd134fb12a2 --- /dev/null +++ b/components/script/task_source/timer.rs @@ -0,0 +1,42 @@ +/* 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 crate::script_runtime::{CommonScriptMsg, ScriptChan, ScriptThreadEventCategory}; +use crate::task::{TaskCanceller, TaskOnce}; +use crate::task_source::{TaskSource, TaskSourceName}; +use msg::constellation_msg::PipelineId; +use std::fmt; + +#[derive(JSTraceable)] +/// https://html.spec.whatwg.org/multipage/#timer-task-source +pub struct TimerTaskSource(pub Box<dyn ScriptChan + Send + 'static>, pub PipelineId); + +impl Clone for TimerTaskSource { + fn clone(&self) -> TimerTaskSource { + TimerTaskSource(self.0.clone(), self.1.clone()) + } +} + +impl fmt::Debug for TimerTaskSource { + fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { + write!(f, "TimerTaskSource(...)") + } +} + +impl TaskSource for TimerTaskSource { + const NAME: TaskSourceName = TaskSourceName::Timer; + + fn queue_with_canceller<T>(&self, task: T, canceller: &TaskCanceller) -> Result<(), ()> + where + T: TaskOnce + 'static, + { + let msg = CommonScriptMsg::Task( + ScriptThreadEventCategory::TimerEvent, + Box::new(canceller.wrap_task(task)), + Some(self.1), + Self::NAME, + ); + self.0.send(msg).map_err(|_| ()) + } +} |