diff options
author | Bruno de Oliveira Abinader <bruno.d@partner.samsung.com> | 2014-01-29 14:24:49 -0400 |
---|---|---|
committer | Bruno de Oliveira Abinader <bruno.d@partner.samsung.com> | 2014-01-30 10:41:24 -0400 |
commit | 43416ef91f03378f7b86ecee98aeea359cb9807c (patch) | |
tree | 9ee15cce1b1f1a7c7fae7c32874ad47c12110be0 /src/components/script/dom/document.rs | |
parent | 0777f211df28e45349a9294a71b81c17800310e7 (diff) | |
download | servo-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.rs | 27 |
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() |