diff options
author | Sankha Narayan Guria <sankha93@gmail.com> | 2014-02-27 03:31:05 +0530 |
---|---|---|
committer | Sankha Narayan Guria <sankha93@gmail.com> | 2014-02-27 03:31:05 +0530 |
commit | 1e9fec9172364346937f375e315e1ce745662611 (patch) | |
tree | a55173568e6dd6a8b4cb4dfcc42ed81204d49874 /src/components/script/dom/htmlanchorelement.rs | |
parent | 47e6e6ec8f2dfbd56e50f9f2ec2762b85087d948 (diff) | |
parent | da16e54243e256dee927f720ce6b9903b62ec14e (diff) | |
download | servo-1e9fec9172364346937f375e315e1ce745662611.tar.gz servo-1e9fec9172364346937f375e315e1ce745662611.zip |
Merge master into this branch
Diffstat (limited to 'src/components/script/dom/htmlanchorelement.rs')
-rw-r--r-- | src/components/script/dom/htmlanchorelement.rs | 25 |
1 files changed, 19 insertions, 6 deletions
diff --git a/src/components/script/dom/htmlanchorelement.rs b/src/components/script/dom/htmlanchorelement.rs index d398a8cbe03..4b4bcf7c115 100644 --- a/src/components/script/dom/htmlanchorelement.rs +++ b/src/components/script/dom/htmlanchorelement.rs @@ -3,27 +3,40 @@ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ use dom::bindings::codegen::HTMLAnchorElementBinding; +use dom::bindings::codegen::InheritTypes::HTMLAnchorElementDerived; +use dom::bindings::js::JS; use dom::bindings::utils::ErrorResult; -use dom::document::AbstractDocument; +use dom::document::Document; use dom::element::HTMLAnchorElementTypeId; +use dom::eventtarget::{EventTarget, NodeTargetTypeId}; use dom::htmlelement::HTMLElement; -use dom::node::{AbstractNode, Node}; +use dom::node::{Node, ElementNodeTypeId}; use servo_util::str::DOMString; +#[deriving(Encodable)] pub struct HTMLAnchorElement { htmlelement: HTMLElement } +impl HTMLAnchorElementDerived for EventTarget { + fn is_htmlanchorelement(&self) -> bool { + match self.type_id { + NodeTargetTypeId(ElementNodeTypeId(HTMLAnchorElementTypeId)) => true, + _ => false + } + } +} + impl HTMLAnchorElement { - pub fn new_inherited(localName: DOMString, document: AbstractDocument) -> HTMLAnchorElement { + pub fn new_inherited(localName: DOMString, document: JS<Document>) -> HTMLAnchorElement { HTMLAnchorElement { htmlelement: HTMLElement::new_inherited(HTMLAnchorElementTypeId, localName, document) } } - pub fn new(localName: DOMString, document: AbstractDocument) -> AbstractNode { - let element = HTMLAnchorElement::new_inherited(localName, document); - Node::reflect_node(@mut element, document, HTMLAnchorElementBinding::Wrap) + pub fn new(localName: DOMString, document: &JS<Document>) -> JS<HTMLAnchorElement> { + let element = HTMLAnchorElement::new_inherited(localName, document.clone()); + Node::reflect_node(~element, document, HTMLAnchorElementBinding::Wrap) } } |