mirror of
https://github.com/servo/servo.git
synced 2025-06-06 16:45:39 +00:00
For a long time, `gfx_traits` has held a lot of things unrelated to graphics and also unrelated to the `gfx` crate (which is mostly about fonts). This is a cleanup which does a few things: 1. Move non `gfx` crate things out of `gfx_traits`. This is important in order to prevent dependency cycles with a different integration between layout, script, and fonts. 2. Rename the `msg` crate to `base`. It didn't really contain anything to do with messages and instead mostly holds ids, which are used across many different crates in Servo. This new crate will hold the *rare* data types that are widely used. Details: - All BackgroundHangMonitor-related things from base to a new `background_hang_monitor_api` crate. - Moved `TraversalDirection` to `script_traits` - Moved `Epoch`-related things from `gfx_traits` to `base`. - Moved `PrintTree` to base. This should be widely useful in Servo. - Moved `WebrenderApi` from `base` to `webrender_traits` and renamed it to `WebRenderFontApi`.
76 lines
2.3 KiB
Rust
76 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 std::fmt;
|
|
use std::result::Result;
|
|
|
|
use base::id::PipelineId;
|
|
use servo_atoms::Atom;
|
|
|
|
use crate::dom::bindings::inheritance::Castable;
|
|
use crate::dom::bindings::refcounted::Trusted;
|
|
use crate::dom::event::{EventBubbles, EventCancelable, EventTask, SimpleEventTask};
|
|
use crate::dom::eventtarget::EventTarget;
|
|
use crate::dom::window::Window;
|
|
use crate::script_runtime::{CommonScriptMsg, ScriptChan, ScriptThreadEventCategory};
|
|
use crate::task::{TaskCanceller, TaskOnce};
|
|
use crate::task_source::{TaskSource, TaskSourceName};
|
|
|
|
#[derive(JSTraceable)]
|
|
pub struct DOMManipulationTaskSource(pub Box<dyn ScriptChan + Send>, #[no_trace] pub PipelineId);
|
|
|
|
impl Clone for DOMManipulationTaskSource {
|
|
fn clone(&self) -> DOMManipulationTaskSource {
|
|
DOMManipulationTaskSource(self.0.clone(), self.1)
|
|
}
|
|
}
|
|
|
|
impl fmt::Debug for DOMManipulationTaskSource {
|
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
|
write!(f, "DOMManipulationTaskSource(...)")
|
|
}
|
|
}
|
|
|
|
impl TaskSource for DOMManipulationTaskSource {
|
|
const NAME: TaskSourceName = TaskSourceName::DOMManipulation;
|
|
|
|
fn queue_with_canceller<T>(&self, task: T, canceller: &TaskCanceller) -> Result<(), ()>
|
|
where
|
|
T: TaskOnce + 'static,
|
|
{
|
|
let msg_task = CommonScriptMsg::Task(
|
|
ScriptThreadEventCategory::ScriptEvent,
|
|
Box::new(canceller.wrap_task(task)),
|
|
Some(self.1),
|
|
DOMManipulationTaskSource::NAME,
|
|
);
|
|
|
|
self.0.send(msg_task).map_err(|_| ())
|
|
}
|
|
}
|
|
|
|
impl DOMManipulationTaskSource {
|
|
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());
|
|
}
|
|
|
|
pub fn queue_simple_event(&self, target: &EventTarget, name: Atom, window: &Window) {
|
|
let target = Trusted::new(target);
|
|
let _ = self.queue(SimpleEventTask { target, name }, window.upcast());
|
|
}
|
|
}
|