aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--components/script/script_thread.rs32
-rw-r--r--components/script/task_source/dom_manipulation.rs4
-rw-r--r--components/script/task_source/user_interaction.rs4
3 files changed, 21 insertions, 19 deletions
diff --git a/components/script/script_thread.rs b/components/script/script_thread.rs
index cfd7715994b..a576af4407e 100644
--- a/components/script/script_thread.rs
+++ b/components/script/script_thread.rs
@@ -221,24 +221,35 @@ pub struct CancellableRunnable<T: Runnable + Send> {
inner: Box<T>,
}
-impl<T: Runnable + Send> Runnable for CancellableRunnable<T> {
+impl<T> CancellableRunnable<T>
+where
+ T: Runnable + Send,
+{
fn is_cancelled(&self) -> bool {
- self.cancelled.as_ref()
- .map(|cancelled| cancelled.load(Ordering::SeqCst))
- .unwrap_or(false)
+ self.cancelled.as_ref().map_or(false, |cancelled| {
+ cancelled.load(Ordering::SeqCst)
+ })
}
+}
+impl<T> Runnable for CancellableRunnable<T>
+where
+ T: Runnable + Send,
+{
fn main_thread_handler(self: Box<CancellableRunnable<T>>, script_thread: &ScriptThread) {
- self.inner.main_thread_handler(script_thread);
+ if !self.is_cancelled() {
+ self.inner.main_thread_handler(script_thread);
+ }
}
fn handler(self: Box<CancellableRunnable<T>>) {
- self.inner.handler()
+ if !self.is_cancelled() {
+ self.inner.handler()
+ }
}
}
pub trait Runnable {
- fn is_cancelled(&self) -> bool { false }
fn name(&self) -> &'static str { unsafe { intrinsics::type_name::<Self>() } }
fn handler(self: Box<Self>) {}
fn main_thread_handler(self: Box<Self>, _script_thread: &ScriptThread) { self.handler(); }
@@ -1281,12 +1292,7 @@ impl ScriptThread {
MainThreadScriptMsg::Common(CommonScriptMsg::RunnableMsg(_, runnable)) => {
// The category of the runnable is ignored by the pattern, however
// it is still respected by profiling (see categorize_msg).
- if !runnable.is_cancelled() {
- debug!("Running runnable.");
- runnable.main_thread_handler(self)
- } else {
- debug!("Not running cancelled runnable.");
- }
+ runnable.main_thread_handler(self)
}
MainThreadScriptMsg::Common(CommonScriptMsg::CollectReports(reports_chan)) =>
self.collect_reports(reports_chan),
diff --git a/components/script/task_source/dom_manipulation.rs b/components/script/task_source/dom_manipulation.rs
index fe25c5f2486..2ba5e297ade 100644
--- a/components/script/task_source/dom_manipulation.rs
+++ b/components/script/task_source/dom_manipulation.rs
@@ -71,8 +71,6 @@ impl fmt::Debug for DOMManipulationTask {
impl DOMManipulationTask {
pub fn handle_task(self, script_thread: &ScriptThread) {
- if !self.0.is_cancelled() {
- self.0.main_thread_handler(script_thread);
- }
+ self.0.main_thread_handler(script_thread);
}
}
diff --git a/components/script/task_source/user_interaction.rs b/components/script/task_source/user_interaction.rs
index c2341cbf82c..1969ee0a41a 100644
--- a/components/script/task_source/user_interaction.rs
+++ b/components/script/task_source/user_interaction.rs
@@ -62,8 +62,6 @@ impl fmt::Debug for UserInteractionTask {
impl UserInteractionTask {
pub fn handle_task(self, script_thread: &ScriptThread) {
- if !self.0.is_cancelled() {
- self.0.main_thread_handler(script_thread);
- }
+ self.0.main_thread_handler(script_thread);
}
}