aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom/htmlheadelement.rs
diff options
context:
space:
mode:
authorManish Goregaokar <manishsmail@gmail.com>2015-04-01 23:19:38 +0530
committerManish Goregaokar <manishsmail@gmail.com>2015-04-01 23:20:38 +0530
commitf41acb589a3ccaa908608478889f6f58b6b3e36b (patch)
tree2fee1e0739841ab51b0a60531e7676c969a778ea /components/script/dom/htmlheadelement.rs
parent4d2ca2d8e2781787dd1fd0b34888dd5a7e3ebad3 (diff)
downloadservo-f41acb589a3ccaa908608478889f6f58b6b3e36b.tar.gz
servo-f41acb589a3ccaa908608478889f6f58b6b3e36b.zip
Give userscripts its own module; panic on broken paths
Diffstat (limited to 'components/script/dom/htmlheadelement.rs')
-rw-r--r--components/script/dom/htmlheadelement.rs49
1 files changed, 5 insertions, 44 deletions
diff --git a/components/script/dom/htmlheadelement.rs b/components/script/dom/htmlheadelement.rs
index ac906229130..cc02c8a0d39 100644
--- a/components/script/dom/htmlheadelement.rs
+++ b/components/script/dom/htmlheadelement.rs
@@ -3,23 +3,16 @@
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
use dom::bindings::codegen::Bindings::HTMLHeadElementBinding;
-use dom::bindings::codegen::Bindings::NodeBinding::NodeMethods;
-use dom::bindings::codegen::Bindings::DocumentBinding::DocumentMethods;
-use dom::bindings::codegen::InheritTypes::{HTMLElementCast, HTMLHeadElementDerived, NodeCast};
-use dom::bindings::js::{JSRef, OptionalRootable, Temporary, RootedReference};
+use dom::bindings::codegen::InheritTypes::{HTMLElementCast, HTMLHeadElementDerived};
+use dom::bindings::js::{JSRef, Temporary};
use dom::document::Document;
use dom::eventtarget::{EventTarget, EventTargetTypeId};
use dom::element::ElementTypeId;
-use dom::element::AttributeHandlers;
use dom::htmlelement::{HTMLElement, HTMLElementTypeId};
-use dom::node::{Node, NodeHelpers, NodeTypeId};
+use dom::node::{Node, NodeTypeId};
+use dom::userscripts::load_script;
use dom::virtualmethods::VirtualMethods;
use util::str::DOMString;
-use util::opts;
-use util::resource_files::resources_dir_path;
-use std::borrow::ToOwned;
-use std::fs::read_dir;
-use std::path::PathBuf;
#[dom_struct]
pub struct HTMLHeadElement {
@@ -52,38 +45,6 @@ impl<'a> VirtualMethods for JSRef<'a, HTMLHeadElement> {
Some(htmlelement as &VirtualMethods)
}
fn bind_to_tree(&self, _tree_in_doc: bool) {
- if let Some(ref path_str) = opts::get().userscripts {
- let node: &JSRef<Node> = NodeCast::from_borrowed_ref(self);
- let first_child = node.GetFirstChild().root();
- let doc = node.owner_doc().root();
- let doc = doc.r();
-
- let path = if &**path_str == "" {
- let mut p = resources_dir_path();
- p.push("user-agent-js");
- p
- } else {
- PathBuf::new(path_str)
- };
-
- let mut files = match read_dir(&path) {
- Ok(d) => d.filter_map(|e| e.ok()).map(|e| e.path()).collect::<Vec<_>>(),
- Err(_) => return
- };
-
- files.sort();
-
- for file in files {
- let name = match file.into_os_string().into_string() {
- Ok(ref s) if s.ends_with(".js") => "file://".to_owned() + &s[..],
- _ => continue
- };
- let new_script = doc.CreateElement("script".to_owned()).unwrap().root();
- let new_script = new_script.r();
- new_script.set_string_attribute(&atom!("src"), name);
- let new_script_node: &JSRef<Node> = NodeCast::from_borrowed_ref(&new_script);
- node.InsertBefore(*new_script_node, first_child.r()).unwrap();
- }
- }
+ load_script(*self);
}
}