aboutsummaryrefslogtreecommitdiffstats
path: root/src/components/script/dom/htmlformelement.rs
diff options
context:
space:
mode:
authorSankha Narayan Guria <sankha93@gmail.com>2014-02-27 03:31:05 +0530
committerSankha Narayan Guria <sankha93@gmail.com>2014-02-27 03:31:05 +0530
commit1e9fec9172364346937f375e315e1ce745662611 (patch)
treea55173568e6dd6a8b4cb4dfcc42ed81204d49874 /src/components/script/dom/htmlformelement.rs
parent47e6e6ec8f2dfbd56e50f9f2ec2762b85087d948 (diff)
parentda16e54243e256dee927f720ce6b9903b62ec14e (diff)
downloadservo-1e9fec9172364346937f375e315e1ce745662611.tar.gz
servo-1e9fec9172364346937f375e315e1ce745662611.zip
Merge master into this branch
Diffstat (limited to 'src/components/script/dom/htmlformelement.rs')
-rw-r--r--src/components/script/dom/htmlformelement.rs36
1 files changed, 25 insertions, 11 deletions
diff --git a/src/components/script/dom/htmlformelement.rs b/src/components/script/dom/htmlformelement.rs
index 554cabd6090..d213c68dbdb 100644
--- a/src/components/script/dom/htmlformelement.rs
+++ b/src/components/script/dom/htmlformelement.rs
@@ -3,28 +3,41 @@
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
use dom::bindings::codegen::HTMLFormElementBinding;
+use dom::bindings::codegen::InheritTypes::HTMLFormElementDerived;
+use dom::bindings::js::JS;
use dom::bindings::utils::ErrorResult;
-use dom::document::AbstractDocument;
-use dom::element::HTMLFormElementTypeId;
+use dom::document::Document;
+use dom::element::{Element, HTMLFormElementTypeId};
+use dom::eventtarget::{EventTarget, NodeTargetTypeId};
use dom::htmlcollection::HTMLCollection;
use dom::htmlelement::HTMLElement;
-use dom::node::{AbstractNode, Node};
+use dom::node::{Node, ElementNodeTypeId};
use servo_util::str::DOMString;
+#[deriving(Encodable)]
pub struct HTMLFormElement {
htmlelement: HTMLElement
}
+impl HTMLFormElementDerived for EventTarget {
+ fn is_htmlformelement(&self) -> bool {
+ match self.type_id {
+ NodeTargetTypeId(ElementNodeTypeId(HTMLFormElementTypeId)) => true,
+ _ => false
+ }
+ }
+}
+
impl HTMLFormElement {
- pub fn new_inherited(localName: DOMString, document: AbstractDocument) -> HTMLFormElement {
+ pub fn new_inherited(localName: DOMString, document: JS<Document>) -> HTMLFormElement {
HTMLFormElement {
htmlelement: HTMLElement::new_inherited(HTMLFormElementTypeId, localName, document)
}
}
- pub fn new(localName: DOMString, document: AbstractDocument) -> AbstractNode {
- let element = HTMLFormElement::new_inherited(localName, document);
- Node::reflect_node(@mut element, document, HTMLFormElementBinding::Wrap)
+ pub fn new(localName: DOMString, document: &JS<Document>) -> JS<HTMLFormElement> {
+ let element = HTMLFormElement::new_inherited(localName, document.clone());
+ Node::reflect_node(~element, document, HTMLFormElementBinding::Wrap)
}
}
@@ -101,9 +114,10 @@ impl HTMLFormElement {
Ok(())
}
- pub fn Elements(&self) -> @mut HTMLCollection {
- let window = self.htmlelement.element.node.owner_doc().document().window;
- HTMLCollection::new(window, ~[])
+ pub fn Elements(&self) -> JS<HTMLCollection> {
+ let doc = self.htmlelement.element.node.owner_doc();
+ let doc = doc.get();
+ HTMLCollection::new(&doc.window, ~[])
}
pub fn Length(&self) -> i32 {
@@ -121,7 +135,7 @@ impl HTMLFormElement {
false
}
- pub fn IndexedGetter(&self, _index: u32, _found: &mut bool) -> AbstractNode {
+ pub fn IndexedGetter(&self, _index: u32, _found: &mut bool) -> JS<Element> {
fail!("Not implemented.")
}
}