aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom/customevent.rs
diff options
context:
space:
mode:
Diffstat (limited to 'components/script/dom/customevent.rs')
-rw-r--r--components/script/dom/customevent.rs79
1 files changed, 79 insertions, 0 deletions
diff --git a/components/script/dom/customevent.rs b/components/script/dom/customevent.rs
new file mode 100644
index 00000000000..159601783ac
--- /dev/null
+++ b/components/script/dom/customevent.rs
@@ -0,0 +1,79 @@
+/* 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::Bindings::CustomEventBinding;
+use dom::bindings::codegen::Bindings::CustomEventBinding::CustomEventMethods;
+use dom::bindings::codegen::Bindings::EventBinding::EventMethods;
+use dom::bindings::codegen::InheritTypes::{EventCast, CustomEventDerived};
+use dom::bindings::error::Fallible;
+use dom::bindings::global::GlobalRef;
+use dom::bindings::js::{JSRef, Temporary};
+use dom::bindings::trace::Traceable;
+use dom::bindings::utils::{Reflectable, Reflector, reflect_dom_object};
+use dom::event::{Event, EventTypeId, CustomEventTypeId};
+use js::jsapi::JSContext;
+use js::jsval::{JSVal, NullValue};
+use servo_util::str::DOMString;
+
+use std::cell::Cell;
+
+#[deriving(Encodable)]
+pub struct CustomEvent {
+ event: Event,
+ detail: Traceable<Cell<Traceable<JSVal>>>,
+}
+
+impl CustomEventDerived for Event {
+ fn is_customevent(&self) -> bool {
+ self.type_id == CustomEventTypeId
+ }
+}
+
+impl CustomEvent {
+ pub fn new_inherited(type_id: EventTypeId) -> CustomEvent {
+ CustomEvent {
+ event: Event::new_inherited(type_id),
+ detail: Traceable::new(Cell::new(Traceable::new(NullValue()))),
+ }
+ }
+
+ pub fn new_uninitialized(global: &GlobalRef) -> Temporary<CustomEvent> {
+ reflect_dom_object(box CustomEvent::new_inherited(CustomEventTypeId),
+ global,
+ CustomEventBinding::Wrap)
+ }
+ pub fn new(global: &GlobalRef, type_: DOMString, bubbles: bool, cancelable: bool, detail: JSVal) -> Temporary<CustomEvent> {
+ let ev = CustomEvent::new_uninitialized(global).root();
+ ev.deref().InitCustomEvent(global.get_cx(), type_, bubbles, cancelable, detail);
+ Temporary::from_rooted(&*ev)
+ }
+ pub fn Constructor(global: &GlobalRef,
+ type_: DOMString,
+ init: &CustomEventBinding::CustomEventInit) -> Fallible<Temporary<CustomEvent>>{
+ Ok(CustomEvent::new(global, type_, init.parent.bubbles, init.parent.cancelable, init.detail))
+ }
+}
+
+impl<'a> CustomEventMethods for JSRef<'a, CustomEvent> {
+ fn Detail(&self, _cx: *mut JSContext) -> JSVal {
+ *self.detail.deref().get()
+ }
+
+ fn InitCustomEvent(&self,
+ _cx: *mut JSContext,
+ type_: DOMString,
+ can_bubble: bool,
+ cancelable: bool,
+ detail: JSVal) {
+ self.detail.deref().set(Traceable::new(detail));
+ let event: &JSRef<Event> = EventCast::from_ref(self);
+ event.InitEvent(type_, can_bubble, cancelable);
+ }
+}
+
+impl Reflectable for CustomEvent {
+ fn reflector<'a>(&'a self) -> &'a Reflector {
+ self.event.reflector()
+ }
+}