Generate HTMLHtmlElement bindings.

This commit is contained in:
Josh Matthews 2013-07-31 19:25:13 -04:00
parent 9a545b13c3
commit e2468160b5
6 changed files with 79 additions and 28 deletions

View file

@ -229,16 +229,6 @@ DOMInterfaces = {
'pointerType': '', 'pointerType': '',
}, },
'HTMLElement': {
'nativeType': 'AbstractNode<ScriptView>',
'pointerType': ''
},
'HTMLHeadElement': {
'nativeType': 'AbstractNode<ScriptView>',
'pointerType': ''
},
'HTMLOptionsCollection': [ 'HTMLOptionsCollection': [
{ {
'nativeType': 'nsHTMLOptionCollection', 'nativeType': 'nsHTMLOptionCollection',
@ -548,6 +538,16 @@ def addExternalIface(iface, nativeType=None, headerFile=None, pointerType=None):
domInterface['pointerType'] = pointerType domInterface['pointerType'] = pointerType
DOMInterfaces[iface] = domInterface DOMInterfaces[iface] = domInterface
def addHTMLElement(element):
DOMInterfaces[element] = {
'nativeType': 'AbstractNode<ScriptView>',
'pointerType': ''
}
addHTMLElement('HTMLElement')
addHTMLElement('HTMLHeadElement')
addHTMLElement('HTMLHtmlElement')
# If you add one of these, you need to make sure nsDOMQS.h has the relevant # If you add one of these, you need to make sure nsDOMQS.h has the relevant
# macros added for it # macros added for it
def addExternalHTMLElement(element): def addExternalHTMLElement(element):

View file

@ -4605,7 +4605,7 @@ class CGBindingRoot(CGThing):
'dom::characterdata::CharacterData', #XXXjdm 'dom::characterdata::CharacterData', #XXXjdm
'dom::node::{AbstractNode, Node, Text}', #XXXjdm 'dom::node::{AbstractNode, Node, Text}', #XXXjdm
'dom::document::{Document, AbstractDocument}', #XXXjdm 'dom::document::{Document, AbstractDocument}', #XXXjdm
'dom::element::{Element, HTMLHeadElement}', #XXXjdm 'dom::element::{Element, HTMLHeadElement, HTMLHtmlElement}', #XXXjdm
'dom::htmlelement::HTMLElement', #XXXjdm 'dom::htmlelement::HTMLElement', #XXXjdm
'dom::htmldocument::HTMLDocument', #XXXjdm 'dom::htmldocument::HTMLDocument', #XXXjdm
'dom::bindings::utils::*', 'dom::bindings::utils::*',

View file

@ -0,0 +1,22 @@
/* -*- Mode: IDL; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* 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/.
*
* The origin of this IDL file is
* http://www.whatwg.org/specs/web-apps/current-work/#the-html-element
* http://www.whatwg.org/specs/web-apps/current-work/#other-elements,-attributes-and-apis
*
* © Copyright 2004-2011 Apple Computer, Inc., Mozilla Foundation, and
* Opera Software ASA. You are granted a license to use, reproduce
* and create derivative works of this document.
*/
// http://www.whatwg.org/specs/web-apps/current-work/#the-html-element
interface HTMLHtmlElement : HTMLElement {};
// http://www.whatwg.org/specs/web-apps/current-work/#other-elements,-attributes-and-apis
partial interface HTMLHtmlElement {
[SetterThrows, Pure]
attribute DOMString version;
};

View file

@ -6,7 +6,8 @@ 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::{HTMLHeadElementTypeId, HTMLHeadElement}; use dom::element::{HTMLHeadElementTypeId, HTMLHtmlElementTypeId};
use dom::element::{HTMLHeadElement, HTMLHtmlElement};
use dom::node::{AbstractNode, Node, ElementNodeTypeId, TextNodeTypeId, CommentNodeTypeId}; use dom::node::{AbstractNode, Node, ElementNodeTypeId, TextNodeTypeId, CommentNodeTypeId};
use dom::node::{DoctypeNodeTypeId, ScriptView, Text}; use dom::node::{DoctypeNodeTypeId, ScriptView, Text};
@ -62,13 +63,18 @@ pub fn init(compartment: @mut Compartment) {
} }
} }
macro_rules! generate_element(
($name: ident) => ({
let node: @mut $name = unsafe { cast::transmute(node.raw_object()) };
node.wrap_object_shared(cx, ptr::null())
})
)
#[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(HTMLHeadElementTypeId) => { ElementNodeTypeId(HTMLHeadElementTypeId) => generate_element!(HTMLHeadElement),
let node: @mut HTMLHeadElement = unsafe { cast::transmute(node.raw_object()) }; ElementNodeTypeId(HTMLHtmlElementTypeId) => generate_element!(HTMLHtmlElement),
node.wrap_object_shared(cx, ptr::null())
}
ElementNodeTypeId(_) => element::create(cx, node).ptr, ElementNodeTypeId(_) => element::create(cx, node).ptr,
CommentNodeTypeId | CommentNodeTypeId |
DoctypeNodeTypeId => text::create(cx, node).ptr, DoctypeNodeTypeId => text::create(cx, node).ptr,

View file

@ -4,7 +4,7 @@
//! Element nodes. //! Element nodes.
use dom::bindings::codegen::HTMLHeadElementBinding; use dom::bindings::codegen::{HTMLHeadElementBinding, HTMLHtmlElementBinding};
use dom::bindings::utils::{DOMString, null_string, ErrorResult}; use dom::bindings::utils::{DOMString, null_string, ErrorResult};
use dom::bindings::utils::{CacheableWrapper, BindingObject, WrapperCache}; use dom::bindings::utils::{CacheableWrapper, BindingObject, WrapperCache};
use dom::clientrect::ClientRect; use dom::clientrect::ClientRect;
@ -124,22 +124,44 @@ pub struct HTMLTitleElement { parent: HTMLElement }
pub struct HTMLUListElement { parent: HTMLElement } pub struct HTMLUListElement { parent: HTMLElement }
pub struct UnknownElement { parent: HTMLElement } pub struct UnknownElement { parent: HTMLElement }
impl CacheableWrapper for HTMLHeadElement { impl HTMLHtmlElement {
pub fn Version(&self) -> DOMString {
null_string
}
pub fn SetVersion(&mut self, _version: &DOMString, _rv: &mut ErrorResult) {
}
}
macro_rules! generate_cacheable_wrapper(
($name: ident, $wrap: path) => (
impl CacheableWrapper for $name {
fn get_wrappercache(&mut self) -> &mut WrapperCache { fn get_wrappercache(&mut self) -> &mut WrapperCache {
self.parent.get_wrappercache() self.parent.get_wrappercache()
} }
fn wrap_object_shared(@mut self, cx: *JSContext, scope: *JSObject) -> *JSObject { fn wrap_object_shared(@mut self, cx: *JSContext, scope: *JSObject) -> *JSObject {
let mut unused = false; let mut unused = false;
HTMLHeadElementBinding::Wrap(cx, scope, self, &mut unused) $wrap(cx, scope, self, &mut unused)
} }
} }
)
)
impl BindingObject for HTMLHeadElement { macro_rules! generate_binding_object(
($name: ident) => (
impl BindingObject for $name {
fn GetParentObject(&self, cx: *JSContext) -> Option<@mut CacheableWrapper> { fn GetParentObject(&self, cx: *JSContext) -> Option<@mut CacheableWrapper> {
self.parent.GetParentObject(cx) self.parent.GetParentObject(cx)
} }
} }
)
)
generate_cacheable_wrapper!(HTMLHeadElement, HTMLHeadElementBinding::Wrap)
generate_binding_object!(HTMLHeadElement)
generate_cacheable_wrapper!(HTMLHtmlElement, HTMLHtmlElementBinding::Wrap)
generate_binding_object!(HTMLHtmlElement)
// //
// Fancier elements // Fancier elements

View file

@ -46,6 +46,7 @@ pub mod dom {
pub mod HTMLDocumentBinding; pub mod HTMLDocumentBinding;
pub mod HTMLElementBinding; pub mod HTMLElementBinding;
pub mod HTMLHeadElementBinding; pub mod HTMLHeadElementBinding;
pub mod HTMLHtmlElementBinding;
pub mod MouseEventBinding; pub mod MouseEventBinding;
pub mod NodeBinding; pub mod NodeBinding;
pub mod PrototypeList; pub mod PrototypeList;