aboutsummaryrefslogtreecommitdiffstats
path: root/components/script
diff options
context:
space:
mode:
authorbors-servo <metajack+bors@gmail.com>2015-01-16 13:51:43 -0700
committerbors-servo <metajack+bors@gmail.com>2015-01-16 13:51:43 -0700
commit2a9acdcb73685f2c5c14b51f33b741690b60cb23 (patch)
tree2fe0d29f45204ca73d5d8299faddf745c6374725 /components/script
parentefae66bccb116ddf41857436718ef1556243a3f2 (diff)
parent4629b7ccf0b0ff27d437f369d42e5c9ffaf79e4a (diff)
downloadservo-2a9acdcb73685f2c5c14b51f33b741690b60cb23.tar.gz
servo-2a9acdcb73685f2c5c14b51f33b741690b60cb23.zip
auto merge of #4540 : saneyuki/servo/internal, r=jdm
Fix #4504
Diffstat (limited to 'components/script')
-rw-r--r--components/script/dom/htmlscriptelement.rs39
1 files changed, 36 insertions, 3 deletions
diff --git a/components/script/dom/htmlscriptelement.rs b/components/script/dom/htmlscriptelement.rs
index 5d290200b23..c2af3ae9f6a 100644
--- a/components/script/dom/htmlscriptelement.rs
+++ b/components/script/dom/htmlscriptelement.rs
@@ -15,6 +15,7 @@ use dom::bindings::codegen::InheritTypes::{ElementCast, HTMLElementCast, NodeCas
use dom::bindings::codegen::InheritTypes::EventTargetCast;
use dom::bindings::global::GlobalRef;
use dom::bindings::js::{JSRef, Temporary, OptionalRootable};
+use dom::bindings::refcounted::Trusted;
use dom::document::Document;
use dom::element::{Element, AttributeHandlers, ElementCreator};
use dom::eventtarget::{EventTarget, EventTargetTypeId, EventTargetHelpers};
@@ -24,6 +25,7 @@ use dom::htmlelement::{HTMLElement, HTMLElementTypeId};
use dom::node::{Node, NodeHelpers, NodeTypeId, window_from_node, CloneChildrenFlag};
use dom::virtualmethods::VirtualMethods;
use dom::window::ScriptHelpers;
+use script_task::{ScriptMsg, Runnable};
use encoding::all::UTF_8;
use encoding::types::{Encoding, DecoderTrap};
@@ -89,6 +91,9 @@ pub trait HTMLScriptElementHelpers {
/// Set the "already started" flag (<https://whatwg.org/html/#already-started>)
fn mark_already_started(self);
+
+ /// Dispatch load event.
+ fn dispatch_load_event(self);
}
/// Supported script types as defined by
@@ -112,6 +117,11 @@ static SCRIPT_JS_MIMES: StaticStringVec = &[
"text/x-javascript",
];
+enum ScriptOrigin {
+ Internal,
+ External,
+}
+
impl<'a> HTMLScriptElementHelpers for JSRef<'a, HTMLScriptElement> {
fn prepare(self) {
// https://html.spec.whatwg.org/multipage/scripting.html#prepare-a-script
@@ -175,7 +185,7 @@ impl<'a> HTMLScriptElementHelpers for JSRef<'a, HTMLScriptElement> {
let page = window.page();
let base_url = page.get_url();
- let (source, url) = match element.get_attribute(ns!(""), &atom!("src")).root() {
+ let (origin, source, url) = match element.get_attribute(ns!(""), &atom!("src")).root() {
Some(src) => {
if src.r().Value().is_empty() {
// TODO: queue a task to fire a simple event named `error` at the element
@@ -191,7 +201,7 @@ impl<'a> HTMLScriptElementHelpers for JSRef<'a, HTMLScriptElement> {
Ok((metadata, bytes)) => {
// TODO: use the charset from step 13.
let source = UTF_8.decode(bytes.as_slice(), DecoderTrap::Replace).unwrap();
- (source, metadata.final_url)
+ (ScriptOrigin::External, source, metadata.final_url)
}
Err(_) => {
error!("error loading script {}", src.r().Value());
@@ -206,11 +216,28 @@ impl<'a> HTMLScriptElementHelpers for JSRef<'a, HTMLScriptElement> {
}
}
}
- None => (text, base_url)
+ None => (ScriptOrigin::Internal, text, base_url)
};
window.evaluate_script_on_global_with_result(source.as_slice(), url.serialize().as_slice());
+ // https://html.spec.whatwg.org/multipage/scripting.html#execute-the-script-block
+ // step 2, substep 10
+ match origin {
+ ScriptOrigin::External => {
+ self.dispatch_load_event();
+ }
+ ScriptOrigin::Internal => {
+ let chan = window.script_chan();
+ let handler = Trusted::new(window.get_cx(), self, chan.clone());
+ chan.send(ScriptMsg::RunnableMsg(box handler));
+ }
+ }
+ }
+
+ fn dispatch_load_event(self) {
+ let window = window_from_node(self).root();
+ let window = window.r();
let event = Event::new(GlobalRef::Window(window),
"load".into_string(),
EventBubbles::DoesNotBubble,
@@ -331,3 +358,9 @@ impl<'a> HTMLScriptElementMethods for JSRef<'a, HTMLScriptElement> {
}
}
+impl Runnable for Trusted<HTMLScriptElement> {
+ fn handler(self: Box<Trusted<HTMLScriptElement>>) {
+ let target = self.to_temporary().root();
+ target.r().dispatch_load_event();
+ }
+}