forked from mirrors/gecko-dev
As described in #1764, this strategy uses the following properties: * DOM members are `JS<T>` types. These cannot be used with being explicitly rooted, but they are required for compiler-derived trace hooks. * Methods that take DOM type arguments receive `&[mut] JSRef<T>`. These are rooted value references that are cloneable but cannot escape. * Methods that return DOM values use `Unrooted<T>`. These are values that may or may not be rooted elsewhere, but callers must root them in order to interact with them in any way. One unsoundness hole exists - `Unrooted` values must be rooted ASAP, or there exists the danger that JSAPI calls could be made that could cause the underlying JS value to be GCed. * All methods are implemented on `JSRef<T>`, enforcing the requirement that all DOM values are rooted for the duration of a method call (with a few exceptions for layout-related code, which cannot root values and therefore interacts with `JS<T>` and `&T` values - this is safe under the assumption that layout code interacts with DOM nodes that are in the tree, therefore rooted, and does not run concurrently with content code) Source-Repo: https://github.com/servo/servo Source-Revision: 731e66ff132e41cdc49bc5324c0e15be19c46ec2
56 lines
1.8 KiB
Rust
56 lines
1.8 KiB
Rust
/* 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::BindingDeclarations::HTMLDataElementBinding;
|
|
use dom::bindings::codegen::InheritTypes::HTMLDataElementDerived;
|
|
use dom::bindings::js::{JSRef, Temporary};
|
|
use dom::bindings::error::ErrorResult;
|
|
use dom::document::Document;
|
|
use dom::element::HTMLDataElementTypeId;
|
|
use dom::eventtarget::{EventTarget, NodeTargetTypeId};
|
|
use dom::htmlelement::HTMLElement;
|
|
use dom::node::{Node, ElementNodeTypeId};
|
|
use servo_util::str::DOMString;
|
|
|
|
#[deriving(Encodable)]
|
|
pub struct HTMLDataElement {
|
|
pub htmlelement: HTMLElement
|
|
}
|
|
|
|
impl HTMLDataElementDerived for EventTarget {
|
|
fn is_htmldataelement(&self) -> bool {
|
|
match self.type_id {
|
|
NodeTargetTypeId(ElementNodeTypeId(HTMLDataElementTypeId)) => true,
|
|
_ => false
|
|
}
|
|
}
|
|
}
|
|
|
|
impl HTMLDataElement {
|
|
pub fn new_inherited(localName: DOMString, document: &JSRef<Document>) -> HTMLDataElement {
|
|
HTMLDataElement {
|
|
htmlelement: HTMLElement::new_inherited(HTMLDataElementTypeId, localName, document)
|
|
}
|
|
}
|
|
|
|
pub fn new(localName: DOMString, document: &JSRef<Document>) -> Temporary<HTMLDataElement> {
|
|
let element = HTMLDataElement::new_inherited(localName, document);
|
|
Node::reflect_node(~element, document, HTMLDataElementBinding::Wrap)
|
|
}
|
|
}
|
|
|
|
pub trait HTMLDataElementMethods {
|
|
fn Value(&self) -> DOMString;
|
|
fn SetValue(&mut self, _value: DOMString) -> ErrorResult;
|
|
}
|
|
|
|
impl<'a> HTMLDataElementMethods for JSRef<'a, HTMLDataElement> {
|
|
fn Value(&self) -> DOMString {
|
|
~""
|
|
}
|
|
|
|
fn SetValue(&mut self, _value: DOMString) -> ErrorResult {
|
|
Ok(())
|
|
}
|
|
}
|