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
67 lines
2.1 KiB
Rust
67 lines
2.1 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::bindings::inheritance::Castable;
|
|
use crate::dom::bindings::refcounted::Trusted;
|
|
use crate::dom::event::{EventBubbles, EventCancelable, EventTask};
|
|
use crate::dom::eventtarget::EventTarget;
|
|
use crate::dom::window::Window;
|
|
use crate::script_runtime::{CommonScriptMsg, ScriptThreadEventCategory};
|
|
use crate::script_thread::MainThreadScriptMsg;
|
|
use crate::task::{TaskCanceller, TaskOnce};
|
|
use crate::task_source::{TaskSource, TaskSourceName};
|
|
use crossbeam_channel::Sender;
|
|
use msg::constellation_msg::PipelineId;
|
|
use servo_atoms::Atom;
|
|
use std::fmt;
|
|
use std::result::Result;
|
|
|
|
#[derive(Clone, JSTraceable)]
|
|
pub struct UserInteractionTaskSource(
|
|
#[no_trace] pub Sender<MainThreadScriptMsg>,
|
|
#[no_trace] pub PipelineId,
|
|
);
|
|
|
|
impl fmt::Debug for UserInteractionTaskSource {
|
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
|
write!(f, "UserInteractionTaskSource(...)")
|
|
}
|
|
}
|
|
|
|
impl TaskSource for UserInteractionTaskSource {
|
|
const NAME: TaskSourceName = TaskSourceName::UserInteraction;
|
|
|
|
fn queue_with_canceller<T>(&self, task: T, canceller: &TaskCanceller) -> Result<(), ()>
|
|
where
|
|
T: TaskOnce + 'static,
|
|
{
|
|
let msg = MainThreadScriptMsg::Common(CommonScriptMsg::Task(
|
|
ScriptThreadEventCategory::InputEvent,
|
|
Box::new(canceller.wrap_task(task)),
|
|
Some(self.1),
|
|
UserInteractionTaskSource::NAME,
|
|
));
|
|
self.0.send(msg).map_err(|_| ())
|
|
}
|
|
}
|
|
|
|
impl UserInteractionTaskSource {
|
|
pub fn queue_event(
|
|
&self,
|
|
target: &EventTarget,
|
|
name: Atom,
|
|
bubbles: EventBubbles,
|
|
cancelable: EventCancelable,
|
|
window: &Window,
|
|
) {
|
|
let target = Trusted::new(target);
|
|
let task = EventTask {
|
|
target,
|
|
name,
|
|
bubbles,
|
|
cancelable,
|
|
};
|
|
let _ = self.queue(task, window.upcast());
|
|
}
|
|
}
|