/* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ use dom::bindings::codegen::DOMParserBinding; use dom::bindings::codegen::DOMParserBinding::SupportedTypeValues::{Text_html, Text_xml}; use dom::bindings::utils::{DOMString, Fallible, Reflector, Reflectable}; use dom::document::{AbstractDocument, Document, XML}; use dom::element::HTMLHtmlElementTypeId; use dom::htmldocument::HTMLDocument; use dom::htmlelement::HTMLElement; use dom::htmlhtmlelement::HTMLHtmlElement; use dom::node::Node; use dom::window::Window; pub struct DOMParser { owner: @mut Window, //XXXjdm Document instead? reflector_: Reflector } impl DOMParser { pub fn new(owner: @mut Window) -> @mut DOMParser { let parser = @mut DOMParser { owner: owner, reflector_: Reflector::new() }; // TODO(tkuehn): This just handles the top-level page. Need to handle subframes. let cx = owner.get_cx(); let scope = owner.reflector().get_jsobject(); parser.wrap_object_shared(cx, scope); parser } pub fn Constructor(owner: @mut Window) -> Fallible<@mut DOMParser> { Ok(DOMParser::new(owner)) } pub fn ParseFromString(&self, _s: &DOMString, ty: DOMParserBinding::SupportedType) -> Fallible { let cx = self.owner.get_cx(); let document = match ty { Text_html => { HTMLDocument::new(self.owner) } Text_xml => { AbstractDocument::as_abstract(cx, @mut Document::new(self.owner, XML)) } _ => { fail!("unsupported document type") } }; let root = @HTMLHtmlElement { htmlelement: HTMLElement::new(HTMLHtmlElementTypeId, ~"html", document) }; let root = unsafe { Node::as_abstract_node(cx, root) }; document.set_root(root); Ok(document) } }