diff options
author | Tetsuharu OHZEKI <saneyuki.snyk@gmail.com> | 2015-02-23 05:35:26 +0900 |
---|---|---|
committer | Tetsuharu OHZEKI <saneyuki.snyk@gmail.com> | 2015-02-23 05:35:26 +0900 |
commit | 36722182c0dee16616f073d4048d78ed7f2a35cd (patch) | |
tree | 3bbba5ca1e08a05cda8ed6b5df45e7dc8c2482f3 /components | |
parent | 287f390c4a56dd8c5960df699d45653227b25d6f (diff) | |
download | servo-36722182c0dee16616f073d4048d78ed7f2a35cd.tar.gz servo-36722182c0dee16616f073d4048d78ed7f2a35cd.zip |
Introduce dom::htmlscriptelement::EventDispatcher.
Diffstat (limited to 'components')
-rw-r--r-- | components/script/dom/htmlscriptelement.rs | 29 |
1 files changed, 19 insertions, 10 deletions
diff --git a/components/script/dom/htmlscriptelement.rs b/components/script/dom/htmlscriptelement.rs index 662e88f02e1..df1a2287462 100644 --- a/components/script/dom/htmlscriptelement.rs +++ b/components/script/dom/htmlscriptelement.rs @@ -40,8 +40,6 @@ use url::UrlParser; pub struct HTMLScriptElement { htmlelement: HTMLElement, - error_occurred: Cell<bool>, - /// https://html.spec.whatwg.org/multipage/scripting.html#already-started already_started: Cell<bool>, @@ -70,7 +68,6 @@ impl HTMLScriptElement { creator: ElementCreator) -> HTMLScriptElement { HTMLScriptElement { htmlelement: HTMLElement::new_inherited(HTMLElementTypeId::HTMLScriptElement, localName, prefix, document), - error_occurred: Cell::new(false), already_started: Cell::new(false), parser_inserted: Cell::new(creator == ElementCreator::ParserCreated), non_blocking: Cell::new(creator != ElementCreator::ParserCreated), @@ -257,18 +254,25 @@ impl<'a> HTMLScriptElementHelpers for JSRef<'a, HTMLScriptElement> { ScriptOrigin::Internal => { let chan = window.script_chan(); let handler = Trusted::new(window.get_cx(), self, chan.clone()); - chan.send(ScriptMsg::RunnableMsg(box handler)).unwrap(); + let dispatcher = Box::new(EventDispatcher { + element: handler, + is_error: false, + }); + chan.send(ScriptMsg::RunnableMsg(dispatcher)).unwrap(); } } } fn queue_error_event(self) { - self.error_occurred.set(true); let window = window_from_node(self).root(); let window = window.r(); let chan = window.script_chan(); let handler = Trusted::new(window.get_cx(), self, chan.clone()); - chan.send(ScriptMsg::RunnableMsg(box handler)).unwrap(); + let dispatcher = Box::new(EventDispatcher { + element: handler, + is_error: true, + }); + chan.send(ScriptMsg::RunnableMsg(dispatcher)).unwrap(); } fn dispatch_load_event(self) { @@ -404,10 +408,15 @@ impl<'a> HTMLScriptElementMethods for JSRef<'a, HTMLScriptElement> { } } -impl Runnable for Trusted<HTMLScriptElement> { - fn handler(self: Box<Trusted<HTMLScriptElement>>) { - let target = self.to_temporary().root(); - if target.r().error_occurred.get() { +struct EventDispatcher { + element: Trusted<HTMLScriptElement>, + is_error: bool, +} + +impl Runnable for EventDispatcher { + fn handler(self: Box<EventDispatcher>) { + let target = self.element.to_temporary().root(); + if self.is_error { target.r().dispatch_error_event(); } else { target.r().dispatch_load_event(); |