aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom/domparser.rs
diff options
context:
space:
mode:
authoryvt <i@yvt.jp>2021-07-10 17:24:27 +0900
committeryvt <i@yvt.jp>2021-07-10 17:55:42 +0900
commit01a7de50ab1843d85295f9dccad7f4c099e7208c (patch)
treeee53fb6e8889deb7b880ee969e6c662e6128d210 /components/script/dom/domparser.rs
parentff8d2cdbbfc7a9dc7f38b7dd47cb350fde39388f (diff)
parent94b613fbdaa2b98f2179fc0bbda13c64e6fa0d38 (diff)
downloadservo-01a7de50ab1843d85295f9dccad7f4c099e7208c.tar.gz
servo-01a7de50ab1843d85295f9dccad7f4c099e7208c.zip
Merge remote-tracking branch 'upstream/master' into feat-cow-infra
`tests/wpt/web-platform-tests/html/browsers/origin/cross-origin-objects/cross-origin-objects.html` was reverted to the upstream version.
Diffstat (limited to 'components/script/dom/domparser.rs')
-rw-r--r--components/script/dom/domparser.rs127
1 files changed, 68 insertions, 59 deletions
diff --git a/components/script/dom/domparser.rs b/components/script/dom/domparser.rs
index 4af6ebf8c60..876d87eef25 100644
--- a/components/script/dom/domparser.rs
+++ b/components/script/dom/domparser.rs
@@ -1,97 +1,106 @@
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
+ * file, You can obtain one at https://mozilla.org/MPL/2.0/. */
-use document_loader::DocumentLoader;
-use dom::bindings::codegen::Bindings::DOMParserBinding;
-use dom::bindings::codegen::Bindings::DOMParserBinding::DOMParserMethods;
-use dom::bindings::codegen::Bindings::DOMParserBinding::SupportedType::Application_xhtml_xml;
-use dom::bindings::codegen::Bindings::DOMParserBinding::SupportedType::Application_xml;
-use dom::bindings::codegen::Bindings::DOMParserBinding::SupportedType::Text_html;
-use dom::bindings::codegen::Bindings::DOMParserBinding::SupportedType::Text_xml;
-use dom::bindings::codegen::Bindings::DocumentBinding::DocumentReadyState;
-use dom::bindings::codegen::Bindings::WindowBinding::WindowMethods;
-use dom::bindings::error::Fallible;
-use dom::bindings::js::{JS, Root};
-use dom::bindings::reflector::{Reflector, reflect_dom_object};
-use dom::bindings::str::DOMString;
-use dom::document::{Document, HasBrowsingContext, IsHTMLDocument};
-use dom::document::DocumentSource;
-use dom::servoparser::ServoParser;
-use dom::window::Window;
+use crate::document_loader::DocumentLoader;
+use crate::dom::bindings::codegen::Bindings::DOMParserBinding;
+use crate::dom::bindings::codegen::Bindings::DOMParserBinding::DOMParserMethods;
+use crate::dom::bindings::codegen::Bindings::DOMParserBinding::SupportedType::Application_xhtml_xml;
+use crate::dom::bindings::codegen::Bindings::DOMParserBinding::SupportedType::Application_xml;
+use crate::dom::bindings::codegen::Bindings::DOMParserBinding::SupportedType::Text_html;
+use crate::dom::bindings::codegen::Bindings::DOMParserBinding::SupportedType::Text_xml;
+use crate::dom::bindings::codegen::Bindings::DocumentBinding::DocumentReadyState;
+use crate::dom::bindings::codegen::Bindings::WindowBinding::WindowMethods;
+use crate::dom::bindings::error::Fallible;
+use crate::dom::bindings::reflector::{reflect_dom_object, Reflector};
+use crate::dom::bindings::root::{Dom, DomRoot};
+use crate::dom::bindings::str::DOMString;
+use crate::dom::document::DocumentSource;
+use crate::dom::document::{Document, HasBrowsingContext, IsHTMLDocument};
+use crate::dom::servoparser::ServoParser;
+use crate::dom::window::Window;
use dom_struct::dom_struct;
use script_traits::DocumentActivity;
#[dom_struct]
pub struct DOMParser {
reflector_: Reflector,
- window: JS<Window>, // XXXjdm Document instead?
+ window: Dom<Window>, // XXXjdm Document instead?
}
impl DOMParser {
fn new_inherited(window: &Window) -> DOMParser {
DOMParser {
reflector_: Reflector::new(),
- window: JS::from_ref(window),
+ window: Dom::from_ref(window),
}
}
- pub fn new(window: &Window) -> Root<DOMParser> {
- reflect_dom_object(box DOMParser::new_inherited(window),
- window,
- DOMParserBinding::Wrap)
+ pub fn new(window: &Window) -> DomRoot<DOMParser> {
+ reflect_dom_object(Box::new(DOMParser::new_inherited(window)), window)
}
- pub fn Constructor(window: &Window) -> Fallible<Root<DOMParser>> {
+ #[allow(non_snake_case)]
+ pub fn Constructor(window: &Window) -> Fallible<DomRoot<DOMParser>> {
Ok(DOMParser::new(window))
}
}
impl DOMParserMethods for DOMParser {
// https://w3c.github.io/DOM-Parsing/#the-domparser-interface
- fn ParseFromString(&self,
- s: DOMString,
- ty: DOMParserBinding::SupportedType)
- -> Fallible<Root<Document>> {
+ fn ParseFromString(
+ &self,
+ s: DOMString,
+ ty: DOMParserBinding::SupportedType,
+ ) -> Fallible<DomRoot<Document>> {
let url = self.window.get_url();
- let content_type = DOMString::from(ty.as_str());
+ let content_type = ty
+ .as_str()
+ .parse()
+ .expect("Supported type is not a MIME type");
let doc = self.window.Document();
let loader = DocumentLoader::new(&*doc.loader());
match ty {
Text_html => {
- let document = Document::new(&self.window,
- HasBrowsingContext::No,
- Some(url.clone()),
- doc.origin().clone(),
- IsHTMLDocument::HTMLDocument,
- Some(content_type),
- None,
- DocumentActivity::Inactive,
- DocumentSource::FromParser,
- loader,
- None,
- None);
- ServoParser::parse_html_document(&document, s, url);
+ let document = Document::new(
+ &self.window,
+ HasBrowsingContext::No,
+ Some(url.clone()),
+ doc.origin().clone(),
+ IsHTMLDocument::HTMLDocument,
+ Some(content_type),
+ None,
+ DocumentActivity::Inactive,
+ DocumentSource::FromParser,
+ loader,
+ None,
+ None,
+ Default::default(),
+ );
+ ServoParser::parse_html_document(&document, Some(s), url);
document.set_ready_state(DocumentReadyState::Complete);
Ok(document)
- }
+ },
Text_xml | Application_xml | Application_xhtml_xml => {
- // FIXME: this should probably be FromParser when we actually parse the string (#3756).
- let document = Document::new(&self.window,
- HasBrowsingContext::No,
- Some(url.clone()),
- doc.origin().clone(),
- IsHTMLDocument::NonHTMLDocument,
- Some(content_type),
- None,
- DocumentActivity::Inactive,
- DocumentSource::NotFromParser,
- loader,
- None,
- None);
- ServoParser::parse_xml_document(&document, s, url);
+ let document = Document::new(
+ &self.window,
+ HasBrowsingContext::No,
+ Some(url.clone()),
+ doc.origin().clone(),
+ IsHTMLDocument::NonHTMLDocument,
+ Some(content_type),
+ None,
+ DocumentActivity::Inactive,
+ DocumentSource::FromParser,
+ loader,
+ None,
+ None,
+ Default::default(),
+ );
+ ServoParser::parse_xml_document(&document, Some(s), url);
+ document.set_ready_state(DocumentReadyState::Complete);
Ok(document)
- }
+ },
}
}
}