diff options
author | Anthony Ramine <n.oxyde@gmail.com> | 2016-11-30 01:23:58 +0100 |
---|---|---|
committer | Anthony Ramine <n.oxyde@gmail.com> | 2016-12-01 11:55:06 +0100 |
commit | 03e04179ae3907afa2036f1bb02ded79156d12ca (patch) | |
tree | 01ec7dca6d43ec6d879536432a45f0ab7ecd03e4 /components/script/dom/range.rs | |
parent | ea4fbbc63a8b499683d874633f246b191520f1e2 (diff) | |
download | servo-03e04179ae3907afa2036f1bb02ded79156d12ca.tar.gz servo-03e04179ae3907afa2036f1bb02ded79156d12ca.zip |
Refactor fragment parsing
Diffstat (limited to 'components/script/dom/range.rs')
-rw-r--r-- | components/script/dom/range.rs | 12 |
1 files changed, 2 insertions, 10 deletions
diff --git a/components/script/dom/range.rs b/components/script/dom/range.rs index 0a5ab7a66df..b2507aeab3b 100644 --- a/components/script/dom/range.rs +++ b/components/script/dom/range.rs @@ -22,7 +22,6 @@ use dom::characterdata::CharacterData; use dom::document::Document; use dom::documentfragment::DocumentFragment; use dom::element::Element; -use dom::htmlbodyelement::HTMLBodyElement; use dom::htmlscriptelement::HTMLScriptElement; use dom::node::{Node, UnbindContext}; use dom::text::Text; @@ -901,6 +900,7 @@ impl RangeMethods for Range { fn CreateContextualFragment(&self, fragment: DOMString) -> Fallible<Root<DocumentFragment>> { // Step 1. let node = self.StartContainer(); + let owner_doc = node.owner_doc(); let element = match node.type_id() { NodeTypeId::Document(_) | NodeTypeId::DocumentFragment => None, NodeTypeId::Element(_) => Some(Root::downcast::<Element>(node).unwrap()), @@ -911,15 +911,7 @@ impl RangeMethods for Range { }; // Step 2. - let should_create_body = element.as_ref().map_or(true, |elem| { - let elem = elem.downcast::<Element>().unwrap(); - elem.local_name() == &local_name!("html") && elem.html_element_in_html_document() - }); - let element: Root<Node> = if should_create_body { - Root::upcast(HTMLBodyElement::new(local_name!("body"), None, &self.StartContainer().owner_doc())) - } else { - Root::upcast(element.unwrap()) - }; + let element = Element::fragment_parsing_context(&owner_doc, element.r()); // Step 3. let fragment_node = try!(element.parse_fragment(fragment)); |