diff options
author | Manish Goregaokar <manishsmail@gmail.com> | 2015-04-01 23:19:38 +0530 |
---|---|---|
committer | Manish Goregaokar <manishsmail@gmail.com> | 2015-04-01 23:20:38 +0530 |
commit | f41acb589a3ccaa908608478889f6f58b6b3e36b (patch) | |
tree | 2fee1e0739841ab51b0a60531e7676c969a778ea /components/script/dom/htmlheadelement.rs | |
parent | 4d2ca2d8e2781787dd1fd0b34888dd5a7e3ebad3 (diff) | |
download | servo-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.rs | 49 |
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); } } |