mirror of
https://github.com/servo/servo.git
synced 2025-08-12 08:55:32 +01:00
Add task_source directory
Use DOMManipulationTaskSource whenever possible
This commit is contained in:
parent
fa93d3f467
commit
3f2cbf0025
17 changed files with 261 additions and 185 deletions
|
@ -14,10 +14,10 @@ use dom::eventtarget::EventTarget;
|
|||
use dom::htmlelement::HTMLElement;
|
||||
use dom::node::{Node, window_from_node};
|
||||
use dom::virtualmethods::VirtualMethods;
|
||||
use script_thread::ScriptThreadEventCategory::DomEvent;
|
||||
use script_thread::{CommonScriptMsg, Runnable};
|
||||
use script_thread::{MainThreadScriptChan, Runnable, ScriptChan};
|
||||
use std::cell::Cell;
|
||||
use string_cache::Atom;
|
||||
use task_source::dom_manipulation::DOMManipulationTask;
|
||||
use util::str::DOMString;
|
||||
|
||||
#[dom_struct]
|
||||
|
@ -69,7 +69,17 @@ impl VirtualMethods for HTMLDetailsElement {
|
|||
if attr.local_name() == &atom!("open") {
|
||||
let counter = self.toggle_counter.get() + 1;
|
||||
self.toggle_counter.set(counter);
|
||||
ToggleEventRunnable::send(&self, counter);
|
||||
|
||||
let window = window_from_node(self);
|
||||
let window = window.r();
|
||||
let task_source = window.dom_manipulation_task_source();
|
||||
let chan = MainThreadScriptChan(window.main_thread_script_chan().clone()).clone();
|
||||
let details = Trusted::new(self, chan.clone());
|
||||
let runnable = box ToggleEventRunnable {
|
||||
element: details,
|
||||
toggle_number: counter
|
||||
};
|
||||
let _ = task_source.queue(DOMManipulationTask::FireToggleEvent(runnable));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -79,20 +89,6 @@ pub struct ToggleEventRunnable {
|
|||
toggle_number: u32
|
||||
}
|
||||
|
||||
impl ToggleEventRunnable {
|
||||
pub fn send(node: &HTMLDetailsElement, toggle_number: u32) {
|
||||
let window = window_from_node(node);
|
||||
let window = window.r();
|
||||
let chan = window.dom_manipulation_task_source();
|
||||
let handler = Trusted::new(node, chan.clone());
|
||||
let dispatcher = ToggleEventRunnable {
|
||||
element: handler,
|
||||
toggle_number: toggle_number,
|
||||
};
|
||||
let _ = chan.send(CommonScriptMsg::RunnableMsg(DomEvent, box dispatcher));
|
||||
}
|
||||
}
|
||||
|
||||
impl Runnable for ToggleEventRunnable {
|
||||
fn handler(self: Box<ToggleEventRunnable>) {
|
||||
let target = self.element.root();
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue