aboutsummaryrefslogtreecommitdiffstats
path: root/src/components/script/dom/document.rs
diff options
context:
space:
mode:
authorBruno de Oliveira Abinader <bruno.d@partner.samsung.com>2014-01-29 14:24:49 -0400
committerBruno de Oliveira Abinader <bruno.d@partner.samsung.com>2014-01-30 10:41:24 -0400
commit43416ef91f03378f7b86ecee98aeea359cb9807c (patch)
tree9ee15cce1b1f1a7c7fae7c32874ad47c12110be0 /src/components/script/dom/document.rs
parent0777f211df28e45349a9294a71b81c17800310e7 (diff)
downloadservo-43416ef91f03378f7b86ecee98aeea359cb9807c.tar.gz
servo-43416ef91f03378f7b86ecee98aeea359cb9807c.zip
Implement document.URL & document.documentURI
Specs: http://dom.spec.whatwg.org/#dom-document-url http://dom.spec.whatwg.org/#dom-document-documenturi This is a sub-task for #1428.
Diffstat (limited to 'src/components/script/dom/document.rs')
-rw-r--r--src/components/script/dom/document.rs27
1 files changed, 22 insertions, 5 deletions
diff --git a/src/components/script/dom/document.rs b/src/components/script/dom/document.rs
index 092b3e63abe..db6302e34d9 100644
--- a/src/components/script/dom/document.rs
+++ b/src/components/script/dom/document.rs
@@ -25,6 +25,7 @@ use html::hubbub_html_parser::build_element_from_tag;
use layout_interface::{DocumentDamageLevel, ContentChangedDocumentDamage};
use servo_util::namespace::Null;
+use extra::url::{Url, from_str};
use js::jsapi::{JSObject, JSContext, JSTracer};
use std::ascii::StrAsciiExt;
use std::cast;
@@ -89,7 +90,8 @@ pub struct Document {
doctype: DocumentType,
idmap: HashMap<DOMString, AbstractNode>,
implementation: Option<@mut DOMImplementation>,
- content_type: DOMString
+ content_type: DOMString,
+ url: Url
}
impl Document {
@@ -110,7 +112,7 @@ impl Document {
abstract
}
- pub fn new_inherited(window: @mut Window, doctype: DocumentType, content_type: Option<DOMString>) -> Document {
+ pub fn new_inherited(window: @mut Window, url: Option<Url>, doctype: DocumentType, content_type: Option<DOMString>) -> Document {
let node_type = match doctype {
HTML => HTMLDocumentTypeId,
SVG | XML => PlainDocumentTypeId
@@ -130,19 +132,23 @@ impl Document {
// http://dom.spec.whatwg.org/#concept-document-content-type
SVG | XML => ~"application/xml"
}
+ },
+ url: match url {
+ None => from_str("about:blank").unwrap(),
+ Some(_url) => _url
}
}
}
- pub fn new(window: @mut Window, doctype: DocumentType, content_type: Option<DOMString>) -> AbstractDocument {
- let document = Document::new_inherited(window, doctype, content_type);
+ pub fn new(window: @mut Window, url: Option<Url>, doctype: DocumentType, content_type: Option<DOMString>) -> AbstractDocument {
+ let document = Document::new_inherited(window, url, doctype, content_type);
Document::reflect_document(@mut document, window, DocumentBinding::Wrap)
}
}
impl Document {
pub fn Constructor(owner: @mut Window) -> Fallible<AbstractDocument> {
- Ok(Document::new(owner, XML, None))
+ Ok(Document::new(owner, None, XML, None))
}
}
@@ -167,6 +173,7 @@ impl Reflectable for Document {
}
impl Document {
+ // http://dom.spec.whatwg.org/#dom-document-implementation
pub fn Implementation(&mut self) -> @mut DOMImplementation {
if self.implementation.is_none() {
self.implementation = Some(DOMImplementation::new(self.window));
@@ -174,6 +181,16 @@ impl Document {
self.implementation.unwrap()
}
+ // http://dom.spec.whatwg.org/#dom-document-url
+ pub fn URL(&self) -> DOMString {
+ self.url.to_str()
+ }
+
+ // http://dom.spec.whatwg.org/#dom-document-documenturi
+ pub fn DocumentURI(&self) -> DOMString {
+ self.URL()
+ }
+
// http://dom.spec.whatwg.org/#dom-document-content_type
pub fn ContentType(&self) -> DOMString {
self.content_type.clone()