mirror of
https://github.com/servo/servo.git
synced 2025-07-22 23:03:42 +01:00
Move Task to its own module
This commit is contained in:
parent
8e78f18d2d
commit
46628fba05
33 changed files with 115 additions and 90 deletions
|
@ -105,15 +105,12 @@ use servo_url::{ImmutableOrigin, MutableOrigin, ServoUrl};
|
|||
use std::cell::Cell;
|
||||
use std::collections::{hash_map, HashMap, HashSet};
|
||||
use std::default::Default;
|
||||
use std::fmt;
|
||||
use std::intrinsics;
|
||||
use std::ops::Deref;
|
||||
use std::option::Option;
|
||||
use std::ptr;
|
||||
use std::rc::Rc;
|
||||
use std::result::Result;
|
||||
use std::sync::Arc;
|
||||
use std::sync::atomic::{AtomicBool, Ordering};
|
||||
use std::sync::mpsc::{Receiver, Select, Sender, channel};
|
||||
use std::thread;
|
||||
use style::context::ReflowGoal;
|
||||
|
@ -206,62 +203,6 @@ impl InProgressLoad {
|
|||
}
|
||||
}
|
||||
|
||||
/// Encapsulated state required to create cancellable tasks from non-script threads.
|
||||
pub struct TaskCanceller {
|
||||
pub cancelled: Option<Arc<AtomicBool>>,
|
||||
}
|
||||
|
||||
impl TaskCanceller {
|
||||
pub fn wrap_task<T>(&self, task: Box<T>) -> Box<Task + Send>
|
||||
where
|
||||
T: Send + Task + 'static,
|
||||
{
|
||||
box CancellableTask {
|
||||
cancelled: self.cancelled.clone(),
|
||||
inner: task,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/// A task that can be discarded by toggling a shared flag.
|
||||
pub struct CancellableTask<T: Send + Task> {
|
||||
cancelled: Option<Arc<AtomicBool>>,
|
||||
inner: Box<T>,
|
||||
}
|
||||
|
||||
impl<T> CancellableTask<T>
|
||||
where
|
||||
T: Send + Task,
|
||||
{
|
||||
fn is_cancelled(&self) -> bool {
|
||||
self.cancelled.as_ref().map_or(false, |cancelled| {
|
||||
cancelled.load(Ordering::SeqCst)
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
impl<T> Task for CancellableTask<T>
|
||||
where
|
||||
T: Send + Task,
|
||||
{
|
||||
fn run(self: Box<Self>) {
|
||||
if !self.is_cancelled() {
|
||||
self.inner.run()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
pub trait Task {
|
||||
fn name(&self) -> &'static str { unsafe { intrinsics::type_name::<Self>() } }
|
||||
fn run(self: Box<Self>);
|
||||
}
|
||||
|
||||
impl fmt::Debug for Task + Send {
|
||||
fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
|
||||
fmt.debug_tuple(self.name()).field(&format_args!("...")).finish()
|
||||
}
|
||||
}
|
||||
|
||||
#[derive(Debug)]
|
||||
enum MixedMessage {
|
||||
FromConstellation(ConstellationControlMsg),
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue