mirror of
https://github.com/servo/servo.git
synced 2025-06-08 00:23:30 +00:00
* Add `no_trace` option to JSTraceable derive * NoTrace wrapper * Port some types to no_trace schematics * Fixing my unsafe mistakes (not tracing traceables) * Add docs & safety guards for no_trace Safety guards (trait shenanigans) guarantees safety usage of `no_trace` * Port canvas_traits to no_trace * Port servo_media to no_trace * Port net_traits to no_trace * Port style to no_trace * Port webgpu to no_trace * Port script_traits to no_trace * Port canvas_traits, devtools_traits, embedder_traits, profile_traits to no_trace * unrooted_must_root lint in seperate file * Add trace_in_no_trace_lint as script_plugin * Composable types in must_not_have_traceable * Introduced HashMapTracedValues wrapper * `HashMap<NoTrace<K>,V>`->`HashMapTracedValues<K,V>` * Port rest of servo's types to no_trace * Port html5ever, euclid, mime and http to no_trace * Port remaining externals to no_trace * Port webxr and Arc<Mutex<_>> * Fix spelling in notrace doc
69 lines
2.3 KiB
Rust
69 lines
2.3 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 https://mozilla.org/MPL/2.0/. */
|
|
|
|
use crate::dom::domexception::DOMErrorName;
|
|
use crate::dom::filereader::{FileReader, GenerationId, ReadMetaData, TrustedFileReader};
|
|
use crate::script_runtime::{CommonScriptMsg, ScriptChan, ScriptThreadEventCategory};
|
|
use crate::task::{TaskCanceller, TaskOnce};
|
|
use crate::task_source::{TaskSource, TaskSourceName};
|
|
use msg::constellation_msg::PipelineId;
|
|
|
|
#[derive(JSTraceable)]
|
|
pub struct FileReadingTaskSource(
|
|
pub Box<dyn ScriptChan + Send + 'static>,
|
|
#[no_trace] pub PipelineId,
|
|
);
|
|
|
|
impl Clone for FileReadingTaskSource {
|
|
fn clone(&self) -> FileReadingTaskSource {
|
|
FileReadingTaskSource(self.0.clone(), self.1.clone())
|
|
}
|
|
}
|
|
|
|
impl TaskSource for FileReadingTaskSource {
|
|
const NAME: TaskSourceName = TaskSourceName::FileReading;
|
|
|
|
fn queue_with_canceller<T>(&self, task: T, canceller: &TaskCanceller) -> Result<(), ()>
|
|
where
|
|
T: TaskOnce + 'static,
|
|
{
|
|
self.0.send(CommonScriptMsg::Task(
|
|
ScriptThreadEventCategory::FileRead,
|
|
Box::new(canceller.wrap_task(task)),
|
|
Some(self.1),
|
|
FileReadingTaskSource::NAME,
|
|
))
|
|
}
|
|
}
|
|
|
|
impl TaskOnce for FileReadingTask {
|
|
fn run_once(self) {
|
|
self.handle_task();
|
|
}
|
|
}
|
|
|
|
#[allow(dead_code)]
|
|
pub enum FileReadingTask {
|
|
ProcessRead(TrustedFileReader, GenerationId),
|
|
ProcessReadData(TrustedFileReader, GenerationId),
|
|
ProcessReadError(TrustedFileReader, GenerationId, DOMErrorName),
|
|
ProcessReadEOF(TrustedFileReader, GenerationId, ReadMetaData, Vec<u8>),
|
|
}
|
|
|
|
impl FileReadingTask {
|
|
pub fn handle_task(self) {
|
|
use self::FileReadingTask::*;
|
|
|
|
match self {
|
|
ProcessRead(reader, gen_id) => FileReader::process_read(reader, gen_id),
|
|
ProcessReadData(reader, gen_id) => FileReader::process_read_data(reader, gen_id),
|
|
ProcessReadError(reader, gen_id, error) => {
|
|
FileReader::process_read_error(reader, gen_id, error)
|
|
},
|
|
ProcessReadEOF(reader, gen_id, metadata, blob_contents) => {
|
|
FileReader::process_read_eof(reader, gen_id, metadata, blob_contents)
|
|
},
|
|
}
|
|
}
|
|
}
|