aboutsummaryrefslogtreecommitdiffstats
path: root/src/components/script/dom/htmlelement.rs
diff options
context:
space:
mode:
authorbors-servo <release+servo@mozilla.com>2014-06-08 20:46:39 -0400
committerbors-servo <release+servo@mozilla.com>2014-06-08 20:46:39 -0400
commite98b03f581912c5bd5175138a3d8dd45fc70a226 (patch)
treea4083d6c6dd07fe690f697cab416b362319b52f6 /src/components/script/dom/htmlelement.rs
parent6e856f4d1c7dcf015b47f640162de14663cada8f (diff)
parent6308ed914c9546e6ac55f47338001885cbd827fe (diff)
downloadservo-e98b03f581912c5bd5175138a3d8dd45fc70a226.tar.gz
servo-e98b03f581912c5bd5175138a3d8dd45fc70a226.zip
auto merge of #2619 : Ms2ger/servo/onclick, r=jdm
Diffstat (limited to 'src/components/script/dom/htmlelement.rs')
-rw-r--r--src/components/script/dom/htmlelement.rs35
1 files changed, 34 insertions, 1 deletions
diff --git a/src/components/script/dom/htmlelement.rs b/src/components/script/dom/htmlelement.rs
index 250cdc65dd1..29ac184987b 100644
--- a/src/components/script/dom/htmlelement.rs
+++ b/src/components/script/dom/htmlelement.rs
@@ -8,9 +8,10 @@ use dom::bindings::codegen::InheritTypes::{ElementCast, HTMLFrameSetElementDeriv
use dom::bindings::codegen::InheritTypes::EventTargetCast;
use dom::bindings::codegen::InheritTypes::{HTMLElementDerived, HTMLBodyElementDerived};
use dom::bindings::js::{JSRef, Temporary};
+use dom::bindings::utils::Reflectable;
use dom::document::Document;
use dom::element::{Element, ElementTypeId, HTMLElementTypeId};
-use dom::eventtarget::{EventTarget, NodeTargetTypeId};
+use dom::eventtarget::{EventTarget, EventTargetHelpers, NodeTargetTypeId};
use dom::node::{Node, ElementNodeTypeId, window_from_node};
use dom::virtualmethods::VirtualMethods;
use dom::window::WindowMethods;
@@ -57,11 +58,23 @@ impl<'a> PrivateHTMLElementHelpers for JSRef<'a, HTMLElement> {
}
pub trait HTMLElementMethods {
+ fn GetOnclick(&self) -> Option<EventHandlerNonNull>;
+ fn SetOnclick(&mut self, listener: Option<EventHandlerNonNull>);
fn GetOnload(&self) -> Option<EventHandlerNonNull>;
fn SetOnload(&mut self, listener: Option<EventHandlerNonNull>);
}
impl<'a> HTMLElementMethods for JSRef<'a, HTMLElement> {
+ fn GetOnclick(&self) -> Option<EventHandlerNonNull> {
+ let eventtarget: &JSRef<EventTarget> = EventTargetCast::from_ref(self);
+ eventtarget.get_event_handler_common("click")
+ }
+
+ fn SetOnclick(&mut self, listener: Option<EventHandlerNonNull>) {
+ let eventtarget: &mut JSRef<EventTarget> = EventTargetCast::from_mut_ref(self);
+ eventtarget.set_event_handler_common("click", listener)
+ }
+
fn GetOnload(&self) -> Option<EventHandlerNonNull> {
if self.is_body_or_frameset() {
let win = window_from_node(self).root();
@@ -84,4 +97,24 @@ impl<'a> VirtualMethods for JSRef<'a, HTMLElement> {
let element: &JSRef<Element> = ElementCast::from_ref(self);
Some(element as &VirtualMethods:)
}
+
+ fn after_set_attr(&self, name: DOMString, value: DOMString) {
+ match self.super_type() {
+ Some(ref s) => s.after_set_attr(name.clone(), value.clone()),
+ _ => (),
+ }
+
+ if name.as_slice().starts_with("on") {
+ let mut window = window_from_node(self).root();
+ let (cx, url, reflector) = (window.get_cx(),
+ window.get_url(),
+ window.reflector().get_jsobject());
+ let mut self_alias = self.clone();
+ let evtarget: &mut JSRef<EventTarget> =
+ EventTargetCast::from_mut_ref(&mut self_alias);
+ evtarget.set_event_handler_uncompiled(cx, url, reflector,
+ name.as_slice().slice_from(2),
+ value);
+ }
+ }
}