/* 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 http://mozilla.org/MPL/2.0/. */ use dom::bindings::inheritance::Castable; use dom::bindings::refcounted::Trusted; use dom::event::{EventBubbles, EventCancelable, EventTask, SimpleEventTask}; use dom::eventtarget::EventTarget; use dom::window::Window; use script_runtime::{CommonScriptMsg, ScriptThreadEventCategory}; use script_thread::MainThreadScriptMsg; use servo_atoms::Atom; use std::fmt; use std::result::Result; use std::sync::mpsc::Sender; use task::{TaskCanceller, TaskOnce}; use task_source::TaskSource; #[derive(Clone, JSTraceable)] pub struct DOMManipulationTaskSource(pub Sender); impl fmt::Debug for DOMManipulationTaskSource { fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { write!(f, "DOMManipulationTaskSource(...)") } } impl TaskSource for DOMManipulationTaskSource { fn queue_with_canceller( &self, task: T, canceller: &TaskCanceller, ) -> Result<(), ()> where T: TaskOnce + 'static, { let msg = MainThreadScriptMsg::Common(CommonScriptMsg::Task( ScriptThreadEventCategory::ScriptEvent, box canceller.wrap_task(task), )); self.0.send(msg).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: target, name: name, bubbles: bubbles, cancelable: 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()); } }