diff options
author | bors-servo <metajack+bors@gmail.com> | 2014-10-08 03:42:34 -0600 |
---|---|---|
committer | bors-servo <metajack+bors@gmail.com> | 2014-10-08 03:42:34 -0600 |
commit | 94731270df688f2df49fdec36ccf7eefd9ed021f (patch) | |
tree | 722b93f855b7e58bec1d658d2a4adb14c1ae3ff5 /components/script/dom/element.rs | |
parent | f49c730720a51d14dacefe9815faf50216b36b91 (diff) | |
parent | 1484acb7afc7703c1f6b3a9320d1071ad1179157 (diff) | |
download | servo-94731270df688f2df49fdec36ccf7eefd9ed021f.tar.gz servo-94731270df688f2df49fdec36ccf7eefd9ed021f.zip |
auto merge of #3605 : Manishearth/servo/form-stuff, r=jdm
Diffstat (limited to 'components/script/dom/element.rs')
-rw-r--r-- | components/script/dom/element.rs | 15 |
1 files changed, 13 insertions, 2 deletions
diff --git a/components/script/dom/element.rs b/components/script/dom/element.rs index 681951136a0..eda3b710712 100644 --- a/components/script/dom/element.rs +++ b/components/script/dom/element.rs @@ -41,6 +41,7 @@ use std::cell::RefCell; use std::default::Default; use std::mem; use string_cache::{Atom, Namespace}; +use url::UrlParser; #[jstraceable] #[must_root] @@ -486,8 +487,18 @@ impl<'a> AttributeHandlers for JSRef<'a, Element> { fn get_url_attribute(self, name: &str) -> DOMString { assert!(name == name.to_ascii_lower().as_slice()); - // XXX Resolve URL. - self.get_string_attribute(name) + if !self.has_attribute(name) { + return "".to_string(); + } + let url = self.get_string_attribute(name); + let doc = document_from_node(self).root(); + let base = doc.url(); + // https://html.spec.whatwg.org/multipage/infrastructure.html#reflect + // XXXManishearth this doesn't handle `javascript:` urls properly + match UrlParser::new().base_url(base).parse(url.as_slice()) { + Ok(parsed) => parsed.serialize(), + Err(_) => "".to_string() + } } fn set_url_attribute(self, name: &str, value: DOMString) { self.set_string_attribute(name, value); |