diff options
Diffstat (limited to 'src/components/script/dom/domparser.rs')
-rw-r--r-- | src/components/script/dom/domparser.rs | 32 |
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) |