diff options
Diffstat (limited to 'components/script')
-rw-r--r-- | components/script/dom/servohtmlparser.rs | 17 | ||||
-rw-r--r-- | components/script/parse/html.rs | 20 |
2 files changed, 17 insertions, 20 deletions
diff --git a/components/script/dom/servohtmlparser.rs b/components/script/dom/servohtmlparser.rs index bfaa5590f3c..75d060ddf29 100644 --- a/components/script/dom/servohtmlparser.rs +++ b/components/script/dom/servohtmlparser.rs @@ -8,6 +8,7 @@ use document_loader::LoadType; use dom::bindings::cell::DOMRefCell; use dom::bindings::codegen::Bindings::ServoHTMLParserBinding; +use dom::bindings::codegen::InheritTypes::NodeCast; use dom::bindings::global::GlobalRef; use dom::bindings::js::{JS, Root}; use dom::bindings::refcounted::Trusted; @@ -15,6 +16,7 @@ use dom::bindings::trace::JSTraceable; use dom::bindings::utils::{Reflector, reflect_dom_object}; use dom::document::Document; use dom::node::{window_from_node, Node}; +use dom::text::Text; use dom::window::Window; use network_listener::PreInvoke; use parse::Parser; @@ -27,7 +29,7 @@ use encoding::all::UTF_8; use encoding::types::{Encoding, DecoderTrap}; use html5ever::tokenizer; use html5ever::tree_builder; -use html5ever::tree_builder::{TreeBuilder, TreeBuilderOpts}; +use html5ever::tree_builder::{NodeOrText, TreeBuilder, TreeBuilderOpts}; use hyper::header::ContentType; use hyper::mime::{Mime, TopLevel, SubLevel}; use js::jsapi::JSTracer; @@ -42,6 +44,19 @@ pub struct Sink { pub document: JS<Document>, } +impl Sink { + pub fn get_or_create(&self, child: NodeOrText<JS<Node>>) -> Root<Node> { + match child { + NodeOrText::AppendNode(n) => n.root(), + NodeOrText::AppendText(t) => { + let doc = self.document.root(); + let text = Text::new(t.into(), &doc); + NodeCast::from_root(text) + } + } + } +} + /// FragmentContext is used only to pass this group of related values /// into functions. #[derive(Copy, Clone)] diff --git a/components/script/parse/html.rs b/components/script/parse/html.rs index 9eabc2bb088..e2a6e483ea6 100644 --- a/components/script/parse/html.rs +++ b/components/script/parse/html.rs @@ -24,7 +24,6 @@ use dom::node::{Node, NodeTypeId}; use dom::node::{document_from_node, window_from_node}; use dom::servohtmlparser; use dom::servohtmlparser::{ServoHTMLParser, FragmentContext}; -use dom::text::Text; use parse::Parser; use encoding::types::Encoding; @@ -33,7 +32,7 @@ use html5ever::Attribute; use html5ever::serialize::TraversalScope; use html5ever::serialize::TraversalScope::{IncludeNode, ChildrenOnly}; use html5ever::serialize::{Serializable, Serializer, AttrRef}; -use html5ever::tree_builder::{TreeSink, QuirksMode, NodeOrText, AppendNode, AppendText, NextParserState}; +use html5ever::tree_builder::{NextParserState, NodeOrText, QuirksMode, TreeSink}; use msg::constellation_msg::PipelineId; use std::borrow::Cow; use std::io::{self, Write}; @@ -42,23 +41,6 @@ use tendril::StrTendril; use url::Url; use util::str::DOMString; -trait SinkHelpers { - fn get_or_create(&self, child: NodeOrText<JS<Node>>) -> Root<Node>; -} - -impl SinkHelpers for servohtmlparser::Sink { - fn get_or_create(&self, child: NodeOrText<JS<Node>>) -> Root<Node> { - match child { - AppendNode(n) => n.root(), - AppendText(t) => { - let doc = self.document.root(); - let text = Text::new(t.into(), doc.r()); - NodeCast::from_root(text) - } - } - } -} - impl<'a> TreeSink for servohtmlparser::Sink { type Handle = JS<Node>; fn get_document(&mut self) -> JS<Node> { |