aboutsummaryrefslogtreecommitdiffstats
path: root/src/components/script/dom/domparser.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/components/script/dom/domparser.rs')
-rw-r--r--src/components/script/dom/domparser.rs32
1 files changed, 20 insertions, 12 deletions
diff --git a/src/components/script/dom/domparser.rs b/src/components/script/dom/domparser.rs
index 1961c8d4661..db2714c642f 100644
--- a/src/components/script/dom/domparser.rs
+++ b/src/components/script/dom/domparser.rs
@@ -4,7 +4,7 @@
use dom::bindings::codegen::BindingDeclarations::DOMParserBinding;
use dom::bindings::codegen::BindingDeclarations::DOMParserBinding::SupportedTypeValues::{Text_html, Text_xml};
-use dom::bindings::js::JS;
+use dom::bindings::js::{JS, JSRef, Temporary};
use dom::bindings::utils::{Reflector, Reflectable, reflect_dom_object};
use dom::bindings::error::{Fallible, FailureUnknown};
use dom::document::{Document, HTMLDocument, NonHTMLDocument};
@@ -18,32 +18,40 @@ pub struct DOMParser {
}
impl DOMParser {
- pub fn new_inherited(owner: JS<Window>) -> DOMParser {
+ pub fn new_inherited(owner: &JSRef<Window>) -> DOMParser {
DOMParser {
- owner: owner,
+ owner: owner.unrooted(),
reflector_: Reflector::new()
}
}
- pub fn new(owner: &JS<Window>) -> JS<DOMParser> {
- reflect_dom_object(~DOMParser::new_inherited(owner.clone()), owner,
+ pub fn new(owner: &JSRef<Window>) -> Temporary<DOMParser> {
+ reflect_dom_object(~DOMParser::new_inherited(owner), owner,
DOMParserBinding::Wrap)
}
- pub fn Constructor(owner: &JS<Window>) -> Fallible<JS<DOMParser>> {
+ pub fn Constructor(owner: &JSRef<Window>) -> Fallible<Temporary<DOMParser>> {
Ok(DOMParser::new(owner))
}
+}
+
+pub trait DOMParserMethods {
+ fn ParseFromString(&self, _s: DOMString, ty: DOMParserBinding::SupportedType)
+ -> Fallible<Temporary<Document>>;
+}
- pub fn ParseFromString(&self,
- _s: DOMString,
- ty: DOMParserBinding::SupportedType)
- -> Fallible<JS<Document>> {
+impl<'a> DOMParserMethods for JSRef<'a, DOMParser> {
+ fn ParseFromString(&self,
+ _s: DOMString,
+ ty: DOMParserBinding::SupportedType)
+ -> Fallible<Temporary<Document>> {
+ let owner = self.owner.root();
match ty {
Text_html => {
- Ok(Document::new(&self.owner, None, HTMLDocument, Some(~"text/html")))
+ Ok(Document::new(&owner.root_ref(), None, HTMLDocument, Some(~"text/html")))
}
Text_xml => {
- Ok(Document::new(&self.owner, None, NonHTMLDocument, Some(~"text/xml")))
+ Ok(Document::new(&owner.root_ref(), None, NonHTMLDocument, Some(~"text/xml")))
}
_ => {
Err(FailureUnknown)