aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom/element.rs
diff options
context:
space:
mode:
authorbors-servo <metajack+bors@gmail.com>2014-10-08 03:42:34 -0600
committerbors-servo <metajack+bors@gmail.com>2014-10-08 03:42:34 -0600
commit94731270df688f2df49fdec36ccf7eefd9ed021f (patch)
tree722b93f855b7e58bec1d658d2a4adb14c1ae3ff5 /components/script/dom/element.rs
parentf49c730720a51d14dacefe9815faf50216b36b91 (diff)
parent1484acb7afc7703c1f6b3a9320d1071ad1179157 (diff)
downloadservo-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.rs15
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);