mirror of
https://github.com/servo/servo.git
synced 2025-06-06 16:45:39 +00:00
No tracing of nop traceable fields (#29926)
* 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
This commit is contained in:
parent
66e0d543cf
commit
9514f670d1
167 changed files with 1903 additions and 1020 deletions
|
@ -13,6 +13,7 @@ use crate::dom::bindings::reflector::DomObject;
|
|||
use crate::dom::bindings::root::{Dom, DomRoot};
|
||||
use crate::dom::bindings::settings_stack::AutoEntryScript;
|
||||
use crate::dom::bindings::str::{DOMString, USVString};
|
||||
use crate::dom::bindings::trace::NoTrace;
|
||||
use crate::dom::document::Document;
|
||||
use crate::dom::element::{
|
||||
cors_setting_for_element, referrer_policy_for_element, reflect_cross_origin_attribute,
|
||||
|
@ -117,9 +118,9 @@ unsafe extern "C" fn off_thread_compilation_callback(
|
|||
let compiled_script = FinishOffThreadStencil(*cx, token.0, ptr::null_mut());
|
||||
|
||||
let load = if compiled_script.is_null() {
|
||||
Err(NetworkError::Internal(
|
||||
Err(NoTrace(NetworkError::Internal(
|
||||
"Off-thread compilation failed.".into(),
|
||||
))
|
||||
)))
|
||||
} else {
|
||||
let script_text = DOMString::from(script);
|
||||
let code = SourceCode::Compiled(CompiledSourceCode {
|
||||
|
@ -144,7 +145,7 @@ unsafe extern "C" fn off_thread_compilation_callback(
|
|||
|
||||
/// An unique id for script element.
|
||||
#[derive(Clone, Copy, Debug, Eq, Hash, JSTraceable, PartialEq)]
|
||||
pub struct ScriptId(Uuid);
|
||||
pub struct ScriptId(#[no_trace] Uuid);
|
||||
|
||||
#[dom_struct]
|
||||
pub struct HTMLScriptElement {
|
||||
|
@ -257,6 +258,7 @@ pub enum SourceCode {
|
|||
pub struct ScriptOrigin {
|
||||
#[ignore_malloc_size_of = "Rc is hard"]
|
||||
code: SourceCode,
|
||||
#[no_trace]
|
||||
url: ServoUrl,
|
||||
external: bool,
|
||||
fetch_options: ScriptFetchOptions,
|
||||
|
@ -326,7 +328,7 @@ fn finish_fetching_a_classic_script(
|
|||
document.finish_load(LoadType::Script(url));
|
||||
}
|
||||
|
||||
pub type ScriptResult = Result<ScriptOrigin, NetworkError>;
|
||||
pub type ScriptResult = Result<ScriptOrigin, NoTrace<NetworkError>>;
|
||||
|
||||
/// The context required for asynchronously loading an external script source.
|
||||
struct ClassicContext {
|
||||
|
@ -400,7 +402,7 @@ impl FetchResponseListener for ClassicContext {
|
|||
&*self.elem.root(),
|
||||
self.kind.clone(),
|
||||
self.url.clone(),
|
||||
Err(err.clone()),
|
||||
Err(NoTrace(err.clone())),
|
||||
);
|
||||
return;
|
||||
},
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue