mirror of
https://github.com/servo/servo.git
synced 2025-06-17 12:54:28 +00:00
Bindings for elements that use HTMLElement.
* aside * section * b * i
This commit is contained in:
parent
a8b03857fc
commit
9cbaf13334
5 changed files with 44 additions and 21 deletions
|
@ -6,6 +6,7 @@ use dom::bindings::element;
|
||||||
use dom::bindings::text;
|
use dom::bindings::text;
|
||||||
use dom::bindings::utils;
|
use dom::bindings::utils;
|
||||||
use dom::bindings::utils::{CacheableWrapper, WrapperCache, DerivedWrapper};
|
use dom::bindings::utils::{CacheableWrapper, WrapperCache, DerivedWrapper};
|
||||||
|
use dom::element::{HTMLElementTypeId};
|
||||||
use dom::element::{HTMLHeadElementTypeId, HTMLHtmlElementTypeId, HTMLAnchorElementTypeId};
|
use dom::element::{HTMLHeadElementTypeId, HTMLHtmlElementTypeId, HTMLAnchorElementTypeId};
|
||||||
use dom::element::{HTMLDivElementTypeId, HTMLImageElementTypeId, HTMLSpanElementTypeId};
|
use dom::element::{HTMLDivElementTypeId, HTMLImageElementTypeId, HTMLSpanElementTypeId};
|
||||||
use dom::element::{HTMLBodyElementTypeId, HTMLHRElementTypeId, HTMLIframeElementTypeId};
|
use dom::element::{HTMLBodyElementTypeId, HTMLHRElementTypeId, HTMLIframeElementTypeId};
|
||||||
|
@ -13,6 +14,7 @@ use dom::element::{HTMLParagraphElementTypeId, HTMLScriptElementTypeId, HTMLMeta
|
||||||
use dom::element::{HTMLOListElementTypeId, HTMLStyleElementTypeId, HTMLTableElementTypeId};
|
use dom::element::{HTMLOListElementTypeId, HTMLStyleElementTypeId, HTMLTableElementTypeId};
|
||||||
use dom::element::{HTMLHeadElement, HTMLHtmlElement, HTMLDivElement, HTMLSpanElement};
|
use dom::element::{HTMLHeadElement, HTMLHtmlElement, HTMLDivElement, HTMLSpanElement};
|
||||||
use dom::element::{HTMLParagraphElement};
|
use dom::element::{HTMLParagraphElement};
|
||||||
|
use dom::htmlelement::HTMLElement;
|
||||||
use dom::htmlanchorelement::HTMLAnchorElement;
|
use dom::htmlanchorelement::HTMLAnchorElement;
|
||||||
use dom::htmlbodyelement::HTMLBodyElement;
|
use dom::htmlbodyelement::HTMLBodyElement;
|
||||||
use dom::htmlhrelement::HTMLHRElement;
|
use dom::htmlhrelement::HTMLHRElement;
|
||||||
|
@ -88,6 +90,7 @@ macro_rules! generate_element(
|
||||||
#[allow(non_implicitly_copyable_typarams)]
|
#[allow(non_implicitly_copyable_typarams)]
|
||||||
pub fn create(cx: *JSContext, node: &mut AbstractNode<ScriptView>) -> *JSObject {
|
pub fn create(cx: *JSContext, node: &mut AbstractNode<ScriptView>) -> *JSObject {
|
||||||
match node.type_id() {
|
match node.type_id() {
|
||||||
|
ElementNodeTypeId(HTMLElementTypeId) => generate_element!(HTMLElement),
|
||||||
ElementNodeTypeId(HTMLAnchorElementTypeId) => generate_element!(HTMLAnchorElement),
|
ElementNodeTypeId(HTMLAnchorElementTypeId) => generate_element!(HTMLAnchorElement),
|
||||||
ElementNodeTypeId(HTMLBodyElementTypeId) => generate_element!(HTMLBodyElement),
|
ElementNodeTypeId(HTMLBodyElementTypeId) => generate_element!(HTMLBodyElement),
|
||||||
ElementNodeTypeId(HTMLDivElementTypeId) => generate_element!(HTMLDivElement),
|
ElementNodeTypeId(HTMLDivElementTypeId) => generate_element!(HTMLDivElement),
|
||||||
|
|
|
@ -64,11 +64,10 @@ impl BindingObject for Element {
|
||||||
|
|
||||||
#[deriving(Eq)]
|
#[deriving(Eq)]
|
||||||
pub enum ElementTypeId {
|
pub enum ElementTypeId {
|
||||||
|
HTMLElementTypeId,
|
||||||
HTMLAnchorElementTypeId,
|
HTMLAnchorElementTypeId,
|
||||||
HTMLAsideElementTypeId,
|
|
||||||
HTMLBRElementTypeId,
|
HTMLBRElementTypeId,
|
||||||
HTMLBodyElementTypeId,
|
HTMLBodyElementTypeId,
|
||||||
HTMLBoldElementTypeId,
|
|
||||||
HTMLDivElementTypeId,
|
HTMLDivElementTypeId,
|
||||||
HTMLFontElementTypeId,
|
HTMLFontElementTypeId,
|
||||||
HTMLFormElementTypeId,
|
HTMLFormElementTypeId,
|
||||||
|
@ -79,7 +78,6 @@ pub enum ElementTypeId {
|
||||||
HTMLIframeElementTypeId,
|
HTMLIframeElementTypeId,
|
||||||
HTMLImageElementTypeId,
|
HTMLImageElementTypeId,
|
||||||
HTMLInputElementTypeId,
|
HTMLInputElementTypeId,
|
||||||
HTMLItalicElementTypeId,
|
|
||||||
HTMLLinkElementTypeId,
|
HTMLLinkElementTypeId,
|
||||||
HTMLListItemElementTypeId,
|
HTMLListItemElementTypeId,
|
||||||
HTMLMetaElementTypeId,
|
HTMLMetaElementTypeId,
|
||||||
|
@ -87,7 +85,6 @@ pub enum ElementTypeId {
|
||||||
HTMLOptionElementTypeId,
|
HTMLOptionElementTypeId,
|
||||||
HTMLParagraphElementTypeId,
|
HTMLParagraphElementTypeId,
|
||||||
HTMLScriptElementTypeId,
|
HTMLScriptElementTypeId,
|
||||||
HTMLSectionElementTypeId,
|
|
||||||
HTMLSelectElementTypeId,
|
HTMLSelectElementTypeId,
|
||||||
HTMLSmallElementTypeId,
|
HTMLSmallElementTypeId,
|
||||||
HTMLSpanElementTypeId,
|
HTMLSpanElementTypeId,
|
||||||
|
@ -105,21 +102,17 @@ pub enum ElementTypeId {
|
||||||
// Regular old elements
|
// Regular old elements
|
||||||
//
|
//
|
||||||
|
|
||||||
pub struct HTMLAsideElement { parent: HTMLElement }
|
|
||||||
pub struct HTMLBRElement { parent: HTMLElement }
|
pub struct HTMLBRElement { parent: HTMLElement }
|
||||||
pub struct HTMLBoldElement { parent: HTMLElement }
|
|
||||||
pub struct HTMLDivElement { parent: HTMLElement }
|
pub struct HTMLDivElement { parent: HTMLElement }
|
||||||
pub struct HTMLFontElement { parent: HTMLElement }
|
pub struct HTMLFontElement { parent: HTMLElement }
|
||||||
pub struct HTMLFormElement { parent: HTMLElement }
|
pub struct HTMLFormElement { parent: HTMLElement }
|
||||||
pub struct HTMLHeadElement { parent: HTMLElement }
|
pub struct HTMLHeadElement { parent: HTMLElement }
|
||||||
pub struct HTMLHtmlElement { parent: HTMLElement }
|
pub struct HTMLHtmlElement { parent: HTMLElement }
|
||||||
pub struct HTMLInputElement { parent: HTMLElement }
|
pub struct HTMLInputElement { parent: HTMLElement }
|
||||||
pub struct HTMLItalicElement { parent: HTMLElement }
|
|
||||||
pub struct HTMLLinkElement { parent: HTMLElement }
|
pub struct HTMLLinkElement { parent: HTMLElement }
|
||||||
pub struct HTMLListItemElement { parent: HTMLElement }
|
pub struct HTMLListItemElement { parent: HTMLElement }
|
||||||
pub struct HTMLOptionElement { parent: HTMLElement }
|
pub struct HTMLOptionElement { parent: HTMLElement }
|
||||||
pub struct HTMLParagraphElement { parent: HTMLElement }
|
pub struct HTMLParagraphElement { parent: HTMLElement }
|
||||||
pub struct HTMLSectionElement { parent: HTMLElement }
|
|
||||||
pub struct HTMLSelectElement { parent: HTMLElement }
|
pub struct HTMLSelectElement { parent: HTMLElement }
|
||||||
pub struct HTMLSmallElement { parent: HTMLElement }
|
pub struct HTMLSmallElement { parent: HTMLElement }
|
||||||
pub struct HTMLSpanElement { parent: HTMLElement }
|
pub struct HTMLSpanElement { parent: HTMLElement }
|
||||||
|
|
|
@ -2,25 +2,26 @@
|
||||||
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
* 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/. */
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||||
|
|
||||||
use dom::element::{HTMLAnchorElementTypeId, HTMLAsideElementTypeId, HTMLBRElementTypeId,
|
use dom::element::{HTMLElementTypeId,
|
||||||
HTMLBodyElementTypeId, HTMLBoldElementTypeId, HTMLDivElementTypeId,
|
HTMLAnchorElementTypeId, HTMLBRElementTypeId,
|
||||||
|
HTMLBodyElementTypeId, HTMLDivElementTypeId,
|
||||||
HTMLFontElementTypeId, HTMLFormElementTypeId, HTMLHRElementTypeId,
|
HTMLFontElementTypeId, HTMLFormElementTypeId, HTMLHRElementTypeId,
|
||||||
HTMLHeadElementTypeId, HTMLHtmlElementTypeId,
|
HTMLHeadElementTypeId, HTMLHtmlElementTypeId,
|
||||||
HTMLImageElementTypeId, HTMLIframeElementTypeId, HTMLInputElementTypeId,
|
HTMLImageElementTypeId, HTMLIframeElementTypeId, HTMLInputElementTypeId,
|
||||||
HTMLItalicElementTypeId, HTMLLinkElementTypeId, HTMLListItemElementTypeId,
|
HTMLLinkElementTypeId, HTMLListItemElementTypeId,
|
||||||
HTMLMetaElementTypeId, HTMLOListElementTypeId, HTMLOptionElementTypeId,
|
HTMLMetaElementTypeId, HTMLOListElementTypeId, HTMLOptionElementTypeId,
|
||||||
HTMLParagraphElementTypeId, HTMLScriptElementTypeId,
|
HTMLParagraphElementTypeId, HTMLScriptElementTypeId,
|
||||||
HTMLSectionElementTypeId, HTMLSelectElementTypeId, HTMLSmallElementTypeId,
|
HTMLSelectElementTypeId, HTMLSmallElementTypeId,
|
||||||
HTMLSpanElementTypeId, HTMLStyleElementTypeId, HTMLTableBodyElementTypeId,
|
HTMLSpanElementTypeId, HTMLStyleElementTypeId, HTMLTableBodyElementTypeId,
|
||||||
HTMLTableCellElementTypeId, HTMLTableElementTypeId,
|
HTMLTableCellElementTypeId, HTMLTableElementTypeId,
|
||||||
HTMLTableRowElementTypeId, HTMLTitleElementTypeId, HTMLUListElementTypeId,
|
HTMLTableRowElementTypeId, HTMLTitleElementTypeId, HTMLUListElementTypeId,
|
||||||
UnknownElementTypeId};
|
UnknownElementTypeId};
|
||||||
use dom::element::{HTMLAsideElement, HTMLBRElement,
|
use dom::element::{HTMLBRElement,
|
||||||
HTMLBoldElement, HTMLDivElement, HTMLFontElement, HTMLFormElement,
|
HTMLDivElement, HTMLFontElement, HTMLFormElement,
|
||||||
HTMLHeadElement, HTMLHeadingElement, HTMLHtmlElement,
|
HTMLHeadElement, HTMLHeadingElement, HTMLHtmlElement,
|
||||||
HTMLInputElement, HTMLItalicElement, HTMLLinkElement,
|
HTMLInputElement, HTMLLinkElement,
|
||||||
HTMLOptionElement, HTMLParagraphElement, HTMLListItemElement,
|
HTMLOptionElement, HTMLParagraphElement, HTMLListItemElement,
|
||||||
HTMLSectionElement, HTMLSelectElement, HTMLSmallElement,
|
HTMLSelectElement, HTMLSmallElement,
|
||||||
HTMLSpanElement, HTMLTableBodyElement,
|
HTMLSpanElement, HTMLTableBodyElement,
|
||||||
HTMLTableCellElement, HTMLTableRowElement,
|
HTMLTableCellElement, HTMLTableRowElement,
|
||||||
HTMLTitleElement, HTMLUListElement};
|
HTMLTitleElement, HTMLUListElement};
|
||||||
|
@ -78,6 +79,16 @@ macro_rules! handle_element(
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
macro_rules! handle_htmlelement(
|
||||||
|
($cx: expr, $tag:expr, $string:expr, $type_id:expr, $ctor:ident) => (
|
||||||
|
if eq_slice($tag, $string) {
|
||||||
|
let _element = @HTMLElement::new($type_id, ($tag).to_str());
|
||||||
|
unsafe {
|
||||||
|
return Node::as_abstract_node(cx, _element);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
type JSResult = ~[~[u8]];
|
type JSResult = ~[~[u8]];
|
||||||
|
|
||||||
|
@ -201,10 +212,8 @@ fn js_script_listener(to_parent: Chan<~[~[u8]]>,
|
||||||
fn build_element_from_tag(cx: *JSContext, tag: &str) -> AbstractNode<ScriptView> {
|
fn build_element_from_tag(cx: *JSContext, tag: &str) -> AbstractNode<ScriptView> {
|
||||||
// TODO (Issue #85): use atoms
|
// TODO (Issue #85): use atoms
|
||||||
handle_element!(cx, tag, "a", HTMLAnchorElementTypeId, HTMLAnchorElement, []);
|
handle_element!(cx, tag, "a", HTMLAnchorElementTypeId, HTMLAnchorElement, []);
|
||||||
handle_element!(cx, tag, "aside", HTMLAsideElementTypeId, HTMLAsideElement, []);
|
|
||||||
handle_element!(cx, tag, "br", HTMLBRElementTypeId, HTMLBRElement, []);
|
handle_element!(cx, tag, "br", HTMLBRElementTypeId, HTMLBRElement, []);
|
||||||
handle_element!(cx, tag, "body", HTMLBodyElementTypeId, HTMLBodyElement, []);
|
handle_element!(cx, tag, "body", HTMLBodyElementTypeId, HTMLBodyElement, []);
|
||||||
handle_element!(cx, tag, "bold", HTMLBoldElementTypeId, HTMLBoldElement, []);
|
|
||||||
handle_element!(cx, tag, "div", HTMLDivElementTypeId, HTMLDivElement, []);
|
handle_element!(cx, tag, "div", HTMLDivElementTypeId, HTMLDivElement, []);
|
||||||
handle_element!(cx, tag, "font", HTMLFontElementTypeId, HTMLFontElement, []);
|
handle_element!(cx, tag, "font", HTMLFontElementTypeId, HTMLFontElement, []);
|
||||||
handle_element!(cx, tag, "form", HTMLFormElementTypeId, HTMLFormElement, []);
|
handle_element!(cx, tag, "form", HTMLFormElementTypeId, HTMLFormElement, []);
|
||||||
|
@ -212,7 +221,6 @@ fn build_element_from_tag(cx: *JSContext, tag: &str) -> AbstractNode<ScriptView>
|
||||||
handle_element!(cx, tag, "head", HTMLHeadElementTypeId, HTMLHeadElement, []);
|
handle_element!(cx, tag, "head", HTMLHeadElementTypeId, HTMLHeadElement, []);
|
||||||
handle_element!(cx, tag, "html", HTMLHtmlElementTypeId, HTMLHtmlElement, []);
|
handle_element!(cx, tag, "html", HTMLHtmlElementTypeId, HTMLHtmlElement, []);
|
||||||
handle_element!(cx, tag, "input", HTMLInputElementTypeId, HTMLInputElement, []);
|
handle_element!(cx, tag, "input", HTMLInputElementTypeId, HTMLInputElement, []);
|
||||||
handle_element!(cx, tag, "i", HTMLItalicElementTypeId, HTMLItalicElement, []);
|
|
||||||
handle_element!(cx, tag, "link", HTMLLinkElementTypeId, HTMLLinkElement, []);
|
handle_element!(cx, tag, "link", HTMLLinkElementTypeId, HTMLLinkElement, []);
|
||||||
handle_element!(cx, tag, "li", HTMLListItemElementTypeId, HTMLListItemElement, []);
|
handle_element!(cx, tag, "li", HTMLListItemElementTypeId, HTMLListItemElement, []);
|
||||||
handle_element!(cx, tag, "meta", HTMLMetaElementTypeId, HTMLMetaElement, []);
|
handle_element!(cx, tag, "meta", HTMLMetaElementTypeId, HTMLMetaElement, []);
|
||||||
|
@ -220,7 +228,6 @@ fn build_element_from_tag(cx: *JSContext, tag: &str) -> AbstractNode<ScriptView>
|
||||||
handle_element!(cx, tag, "option", HTMLOptionElementTypeId, HTMLOptionElement, []);
|
handle_element!(cx, tag, "option", HTMLOptionElementTypeId, HTMLOptionElement, []);
|
||||||
handle_element!(cx, tag, "p", HTMLParagraphElementTypeId, HTMLParagraphElement, []);
|
handle_element!(cx, tag, "p", HTMLParagraphElementTypeId, HTMLParagraphElement, []);
|
||||||
handle_element!(cx, tag, "script", HTMLScriptElementTypeId, HTMLScriptElement, []);
|
handle_element!(cx, tag, "script", HTMLScriptElementTypeId, HTMLScriptElement, []);
|
||||||
handle_element!(cx, tag, "section", HTMLSectionElementTypeId, HTMLSectionElement, []);
|
|
||||||
handle_element!(cx, tag, "select", HTMLSelectElementTypeId, HTMLSelectElement, []);
|
handle_element!(cx, tag, "select", HTMLSelectElementTypeId, HTMLSelectElement, []);
|
||||||
handle_element!(cx, tag, "small", HTMLSmallElementTypeId, HTMLSmallElement, []);
|
handle_element!(cx, tag, "small", HTMLSmallElementTypeId, HTMLSmallElement, []);
|
||||||
handle_element!(cx, tag, "span", HTMLSpanElementTypeId, HTMLSpanElement, []);
|
handle_element!(cx, tag, "span", HTMLSpanElementTypeId, HTMLSpanElement, []);
|
||||||
|
@ -242,6 +249,12 @@ fn build_element_from_tag(cx: *JSContext, tag: &str) -> AbstractNode<ScriptView>
|
||||||
handle_element!(cx, tag, "h5", HTMLHeadingElementTypeId, HTMLHeadingElement, [(level: Heading5)]);
|
handle_element!(cx, tag, "h5", HTMLHeadingElementTypeId, HTMLHeadingElement, [(level: Heading5)]);
|
||||||
handle_element!(cx, tag, "h6", HTMLHeadingElementTypeId, HTMLHeadingElement, [(level: Heading6)]);
|
handle_element!(cx, tag, "h6", HTMLHeadingElementTypeId, HTMLHeadingElement, [(level: Heading6)]);
|
||||||
|
|
||||||
|
|
||||||
|
handle_htmlelement!(cx, tag, "aside", HTMLElementTypeId, HTMLElement);
|
||||||
|
handle_htmlelement!(cx, tag, "b", HTMLElementTypeId, HTMLElement);
|
||||||
|
handle_htmlelement!(cx, tag, "i", HTMLElementTypeId, HTMLElement);
|
||||||
|
handle_htmlelement!(cx, tag, "section", HTMLElementTypeId, HTMLElement);
|
||||||
|
|
||||||
unsafe {
|
unsafe {
|
||||||
Node::as_abstract_node(cx, @Element::new(UnknownElementTypeId, tag.to_str()))
|
Node::as_abstract_node(cx, @Element::new(UnknownElementTypeId, tag.to_str()))
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,5 +21,9 @@
|
||||||
<iframe></iframe>
|
<iframe></iframe>
|
||||||
<ol type="1"></ol>
|
<ol type="1"></ol>
|
||||||
<table></table>
|
<table></table>
|
||||||
|
<section>section</section>
|
||||||
|
<aside>aside</aside>
|
||||||
|
<b>b</b>
|
||||||
|
<i>i</i>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -141,6 +141,16 @@ window.alert(tags.length);
|
||||||
window.alert(tags[0]);
|
window.alert(tags[0]);
|
||||||
window.alert(tags[0].tagName);
|
window.alert(tags[0].tagName);
|
||||||
|
|
||||||
|
window.alert("HTMLElement:");
|
||||||
|
let tagList = ["section", "aside", "b", "i"];
|
||||||
|
for (let i = 0, l = tagList.length; i < l; ++i) {
|
||||||
|
let tags = document.getElementsByTagName(tagList[i]);
|
||||||
|
window.alert(tags);
|
||||||
|
window.alert(tags.length);
|
||||||
|
window.alert(tags[0].tagName);
|
||||||
|
window.alert(tags[0] instanceof HTMLElement);
|
||||||
|
}
|
||||||
|
|
||||||
//TODO: Doesn't work until we throw proper exceptions instead of returning 0 on
|
//TODO: Doesn't work until we throw proper exceptions instead of returning 0 on
|
||||||
// unwrap failure.
|
// unwrap failure.
|
||||||
/*try {
|
/*try {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue