From 152f44db522774f0a681e2d55f1cb6806fee0665 Mon Sep 17 00:00:00 2001 From: Ms2ger Date: Thu, 31 Oct 2013 20:18:09 +0100 Subject: [PATCH] Introduce HTMLScriptElement::new. --- src/components/script/dom/htmlscriptelement.rs | 17 +++++++++++++++++ .../script/html/hubbub_html_parser.rs | 2 +- 2 files changed, 18 insertions(+), 1 deletion(-) diff --git a/src/components/script/dom/htmlscriptelement.rs b/src/components/script/dom/htmlscriptelement.rs index f3de42eae26..0925a0109f5 100644 --- a/src/components/script/dom/htmlscriptelement.rs +++ b/src/components/script/dom/htmlscriptelement.rs @@ -2,14 +2,31 @@ * 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::HTMLScriptElementBinding; use dom::bindings::utils::{DOMString, ErrorResult}; +use dom::document::AbstractDocument; +use dom::element::HTMLScriptElementTypeId; use dom::htmlelement::HTMLElement; +use dom::node::{AbstractNode, Node, ScriptView}; use servo_util::tree::ElementLike; pub struct HTMLScriptElement { htmlelement: HTMLElement, } +impl HTMLScriptElement { + pub fn new_inherited(localName: ~str, document: AbstractDocument) -> HTMLScriptElement { + HTMLScriptElement { + htmlelement: HTMLElement::new(HTMLScriptElementTypeId, localName, document) + } + } + + pub fn new(localName: ~str, document: AbstractDocument) -> AbstractNode { + let element = HTMLScriptElement::new_inherited(localName, document); + Node::reflect_node(@mut element, document, HTMLScriptElementBinding::Wrap) + } +} + impl HTMLScriptElement { pub fn Src(&self) -> DOMString { self.htmlelement.element.get_attr("src").map(|s| s.to_str()) diff --git a/src/components/script/html/hubbub_html_parser.rs b/src/components/script/html/hubbub_html_parser.rs index e8f5fc714a9..6e7f6e5b2d5 100644 --- a/src/components/script/html/hubbub_html_parser.rs +++ b/src/components/script/html/hubbub_html_parser.rs @@ -252,7 +252,6 @@ pub fn build_element_from_tag(cx: *JSContext, tag: &str, document: AbstractDocum handle_element!(cx, document, tag, "pre", HTMLPreElementTypeId, HTMLPreElement, []); handle_element!(cx, document, tag, "progress",HTMLProgressElementTypeId, HTMLProgressElement, []); handle_element!(cx, document, tag, "q", HTMLQuoteElementTypeId, HTMLQuoteElement, []); - handle_element!(cx, document, tag, "script", HTMLScriptElementTypeId, HTMLScriptElement, []); handle_htmlelement!(cx, document, tag, "aside", HTMLElementTypeId, HTMLElement); handle_htmlelement!(cx, document, tag, "b", HTMLElementTypeId, HTMLElement); @@ -272,6 +271,7 @@ pub fn build_element_from_tag(cx: *JSContext, tag: &str, document: AbstractDocum handle_newable_element!(document, tag, "h6", HTMLHeadingElement, Heading6); handle_newable_element!(document, tag, "iframe", HTMLIFrameElement); handle_newable_element!(document, tag, "img", HTMLImageElement); + handle_newable_element!(document, tag, "script", HTMLScriptElement); handle_newable_element!(document, tag, "select", HTMLSelectElement); handle_newable_element!(document, tag, "source", HTMLSourceElement); handle_newable_element!(document, tag, "span", HTMLSpanElement);