aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom/range.rs
diff options
context:
space:
mode:
authorAnthony Ramine <n.oxyde@gmail.com>2016-11-30 01:23:58 +0100
committerAnthony Ramine <n.oxyde@gmail.com>2016-12-01 11:55:06 +0100
commit03e04179ae3907afa2036f1bb02ded79156d12ca (patch)
tree01ec7dca6d43ec6d879536432a45f0ab7ecd03e4 /components/script/dom/range.rs
parentea4fbbc63a8b499683d874633f246b191520f1e2 (diff)
downloadservo-03e04179ae3907afa2036f1bb02ded79156d12ca.tar.gz
servo-03e04179ae3907afa2036f1bb02ded79156d12ca.zip
Refactor fragment parsing
Diffstat (limited to 'components/script/dom/range.rs')
-rw-r--r--components/script/dom/range.rs12
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));