aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAnthony Ramine <n.oxyde@gmail.com>2015-08-27 02:11:37 +0200
committerAnthony Ramine <n.oxyde@gmail.com>2015-08-27 16:59:03 +0200
commitc0cff59df895f2ed495bbd29ff5c8c8aec6ed453 (patch)
tree0a14898eec89c162049fc52468e5186c4d6fc9fc
parent275907f256814e492c53086f455938f11fedaf42 (diff)
downloadservo-c0cff59df895f2ed495bbd29ff5c8c8aec6ed453.tar.gz
servo-c0cff59df895f2ed495bbd29ff5c8c8aec6ed453.zip
Remove SinkHelpers
Method get_or_create() is now directly on servohtmlparser::Sink.
-rw-r--r--components/script/dom/servohtmlparser.rs17
-rw-r--r--components/script/parse/html.rs20
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> {