aboutsummaryrefslogtreecommitdiffstats
path: root/components/script
diff options
context:
space:
mode:
authorbors-servo <lbergstrom+bors@mozilla.com>2016-09-17 10:33:03 -0500
committerGitHub <noreply@github.com>2016-09-17 10:33:03 -0500
commit83f687a7be2d4cdda11f5ec03133c23d6d621e78 (patch)
tree27d6834e04a3d7325d14ee4b7bb9074044fa8f36 /components/script
parent6ac9dfdd34299d284995f5e7f957f515f4a2c880 (diff)
parent8b10cca91fb8163d648838706525b25935e8374b (diff)
downloadservo-83f687a7be2d4cdda11f5ec03133c23d6d621e78.tar.gz
servo-83f687a7be2d4cdda11f5ec03133c23d6d621e78.zip
Auto merge of #13292 - creativcoder:extendable, r=jdm
Implement ExtendableEvent as base type for ServiceWorker events <!-- Please describe your changes on the following line: --> r? @jdm --- <!-- Thank you for contributing to Servo! Please replace each `[ ]` by `[X]` when the step is complete, and replace `__` with appropriate data: --> - [X] `./mach build -d` does not report any errors - [X] `./mach test-tidy` does not report any errors - [ ] These changes fix #__ (github issue number if applicable). <!-- Either: --> - [X] These changes do not require tests because refactor <!-- Pull requests that do not address these steps are welcome, but they will require additional verification as part of the review process. --> <!-- Reviewable:start --> --- This change is [<img src="https://reviewable.io/review_button.svg" height="34" align="absmiddle" alt="Reviewable"/>](https://reviewable.io/reviews/servo/servo/13292) <!-- Reviewable:end -->
Diffstat (limited to 'components/script')
-rw-r--r--components/script/dom/extendableevent.rs68
-rw-r--r--components/script/dom/extendablemessageevent.rs95
-rw-r--r--components/script/dom/mod.rs2
-rw-r--r--components/script/dom/serviceworkerglobalscope.rs15
-rw-r--r--components/script/dom/webidls/ExtendableEvent.webidl17
-rw-r--r--components/script/dom/webidls/ExtendableMessageEvent.webidl24
6 files changed, 218 insertions, 3 deletions
diff --git a/components/script/dom/extendableevent.rs b/components/script/dom/extendableevent.rs
new file mode 100644
index 00000000000..76756b40c71
--- /dev/null
+++ b/components/script/dom/extendableevent.rs
@@ -0,0 +1,68 @@
+/* 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::EventBinding::EventMethods;
+use dom::bindings::codegen::Bindings::ExtendableEventBinding;
+use dom::bindings::error::{Error, ErrorResult, Fallible};
+use dom::bindings::global::GlobalRef;
+use dom::bindings::inheritance::Castable;
+use dom::bindings::js::Root;
+use dom::bindings::reflector::reflect_dom_object;
+use dom::bindings::str::DOMString;
+use dom::event::Event;
+use js::jsapi::{HandleValue, JSContext};
+use string_cache::Atom;
+
+// https://w3c.github.io/ServiceWorker/#extendable-event
+#[dom_struct]
+pub struct ExtendableEvent {
+ event: Event,
+ extensions_allowed: bool
+}
+
+impl ExtendableEvent {
+ pub fn new_inherited() -> ExtendableEvent {
+ ExtendableEvent {
+ event: Event::new_inherited(),
+ extensions_allowed: true
+ }
+ }
+ pub fn new(global: GlobalRef,
+ type_: Atom,
+ bubbles: bool,
+ cancelable: bool)
+ -> Root<ExtendableEvent> {
+ let ev = reflect_dom_object(box ExtendableEvent::new_inherited(), global, ExtendableEventBinding::Wrap);
+ {
+ let event = ev.upcast::<Event>();
+ event.init_event(type_, bubbles, cancelable);
+ }
+ ev
+ }
+
+ pub fn Constructor(global: GlobalRef,
+ type_: DOMString,
+ init: &ExtendableEventBinding::ExtendableEventInit) -> Fallible<Root<ExtendableEvent>> {
+ Ok(ExtendableEvent::new(global,
+ Atom::from(type_),
+ init.parent.bubbles,
+ init.parent.cancelable))
+ }
+
+ // https://w3c.github.io/ServiceWorker/#wait-until-method
+ pub fn WaitUntil(&self, _cx: *mut JSContext, val: HandleValue) -> ErrorResult {
+ // Step 1
+ if !self.extensions_allowed {
+ return Err(Error::InvalidState);
+ }
+ // Step 2
+ // TODO add a extended_promises array to enqueue the `val`
+ Ok(())
+ }
+
+ // https://dom.spec.whatwg.org/#dom-event-istrusted
+ pub fn IsTrusted(&self) -> bool {
+ self.event.IsTrusted()
+ }
+}
diff --git a/components/script/dom/extendablemessageevent.rs b/components/script/dom/extendablemessageevent.rs
new file mode 100644
index 00000000000..202c81c0416
--- /dev/null
+++ b/components/script/dom/extendablemessageevent.rs
@@ -0,0 +1,95 @@
+/* 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::ExtendableMessageEventBinding;
+use dom::bindings::codegen::Bindings::ExtendableMessageEventBinding::ExtendableMessageEventMethods;
+use dom::bindings::error::Fallible;
+use dom::bindings::global::GlobalRef;
+use dom::bindings::inheritance::Castable;
+use dom::bindings::js::Root;
+use dom::bindings::reflector::reflect_dom_object;
+use dom::bindings::str::DOMString;
+use dom::event::Event;
+use dom::eventtarget::EventTarget;
+use dom::extendableevent::ExtendableEvent;
+use js::jsapi::{HandleValue, Heap, JSContext};
+use js::jsval::JSVal;
+use std::default::Default;
+use string_cache::Atom;
+
+#[dom_struct]
+pub struct ExtendableMessageEvent {
+ event: ExtendableEvent,
+ data: Heap<JSVal>,
+ origin: DOMString,
+ lastEventId: DOMString,
+}
+
+impl ExtendableMessageEvent {
+ pub fn new(global: GlobalRef, type_: Atom,
+ bubbles: bool, cancelable: bool,
+ data: HandleValue, origin: DOMString, lastEventId: DOMString)
+ -> Root<ExtendableMessageEvent> {
+ let mut ev = box ExtendableMessageEvent {
+ event: ExtendableEvent::new_inherited(),
+ data: Heap::default(),
+ origin: origin,
+ lastEventId: lastEventId,
+ };
+ ev.data.set(data.get());
+ let ev = reflect_dom_object(ev, global, ExtendableMessageEventBinding::Wrap);
+ {
+ let event = ev.upcast::<Event>();
+ event.init_event(type_, bubbles, cancelable);
+ }
+ ev
+ }
+
+ pub fn Constructor(global: GlobalRef,
+ type_: DOMString,
+ init: &ExtendableMessageEventBinding::ExtendableMessageEventInit)
+ -> Fallible<Root<ExtendableMessageEvent>> {
+ rooted!(in(global.get_cx()) let data = init.data);
+ let ev = ExtendableMessageEvent::new(global, Atom::from(type_),
+ init.parent.parent.bubbles,
+ init.parent.parent.cancelable,
+ data.handle(),
+ init.origin.clone().unwrap(),
+ init.lastEventId.clone().unwrap());
+ Ok(ev)
+ }
+}
+
+impl ExtendableMessageEvent {
+ pub fn dispatch_jsval(target: &EventTarget,
+ scope: GlobalRef,
+ message: HandleValue) {
+ let Extendablemessageevent = ExtendableMessageEvent::new(
+ scope, atom!("message"), false, false, message,
+ DOMString::new(), DOMString::new());
+ Extendablemessageevent.upcast::<Event>().fire(target);
+ }
+}
+
+impl ExtendableMessageEventMethods for ExtendableMessageEvent {
+ // https://w3c.github.io/ServiceWorker/#extendablemessage-event-data-attribute
+ fn Data(&self, _cx: *mut JSContext) -> JSVal {
+ self.data.get()
+ }
+
+ // https://w3c.github.io/ServiceWorker/#extendablemessage-event-origin-attribute
+ fn Origin(&self) -> DOMString {
+ self.origin.clone()
+ }
+
+ // https://w3c.github.io/ServiceWorker/#extendablemessage-event-lasteventid-attribute
+ fn LastEventId(&self) -> DOMString {
+ self.lastEventId.clone()
+ }
+
+ // https://dom.spec.whatwg.org/#dom-event-istrusted
+ fn IsTrusted(&self) -> bool {
+ self.event.IsTrusted()
+ }
+}
diff --git a/components/script/dom/mod.rs b/components/script/dom/mod.rs
index 1e7832478cd..5f6b4fffbdc 100644
--- a/components/script/dom/mod.rs
+++ b/components/script/dom/mod.rs
@@ -267,6 +267,8 @@ pub mod event;
pub mod eventdispatcher;
pub mod eventsource;
pub mod eventtarget;
+pub mod extendableevent;
+pub mod extendablemessageevent;
pub mod file;
pub mod filelist;
pub mod filereader;
diff --git a/components/script/dom/serviceworkerglobalscope.rs b/components/script/dom/serviceworkerglobalscope.rs
index f473c6cadb2..d3cb268e7df 100644
--- a/components/script/dom/serviceworkerglobalscope.rs
+++ b/components/script/dom/serviceworkerglobalscope.rs
@@ -13,8 +13,10 @@ use dom::bindings::inheritance::Castable;
use dom::bindings::js::{Root, RootCollection};
use dom::bindings::reflector::Reflectable;
use dom::bindings::str::DOMString;
+use dom::event::Event;
use dom::eventtarget::EventTarget;
-use dom::messageevent::MessageEvent;
+use dom::extendableevent::ExtendableEvent;
+use dom::extendablemessageevent::ExtendableMessageEvent;
use dom::workerglobalscope::WorkerGlobalScope;
use ipc_channel::ipc::{self, IpcSender, IpcReceiver};
use ipc_channel::router::ROUTER;
@@ -195,7 +197,7 @@ impl ServiceWorkerGlobalScope {
let _ = timer_chan.send(());
});
- scope.upcast::<EventTarget>().fire_simple_event("activate");
+ global.dispatch_activate();
let reporter_name = format!("service-worker-reporter-{}", random::<u64>());
scope.mem_profiler_chan().run_with_memory_reporting(|| {
while let Ok(event) = global.receive_event() {
@@ -243,7 +245,7 @@ impl ServiceWorkerGlobalScope {
let _ac = JSAutoCompartment::new(scope.get_cx(), scope.reflector().get_jsobject().get());
rooted!(in(scope.get_cx()) let mut message = UndefinedValue());
data.read(GlobalRef::Worker(scope), message.handle_mut());
- MessageEvent::dispatch_jsval(target, GlobalRef::Worker(scope), message.handle());
+ ExtendableMessageEvent::dispatch_jsval(target, GlobalRef::Worker(scope), message.handle());
},
CommonWorker(WorkerScriptMsg::Common(CommonScriptMsg::RunnableMsg(_, runnable))) => {
runnable.handler()
@@ -309,6 +311,13 @@ impl ServiceWorkerGlobalScope {
sender: self.own_sender.clone()
}
}
+
+ fn dispatch_activate(&self) {
+ let global = GlobalRef::Worker(self.upcast::<WorkerGlobalScope>());
+ let event = ExtendableEvent::new(global, atom!("activate"), false, false);
+ let event = (&*event).upcast::<Event>();
+ self.upcast::<EventTarget>().dispatch_event(event);
+ }
}
#[allow(unsafe_code)]
diff --git a/components/script/dom/webidls/ExtendableEvent.webidl b/components/script/dom/webidls/ExtendableEvent.webidl
new file mode 100644
index 00000000000..09cb253e892
--- /dev/null
+++ b/components/script/dom/webidls/ExtendableEvent.webidl
@@ -0,0 +1,17 @@
+/* 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/. */
+
+// https://w3c.github.io/ServiceWorker/#extendable-event
+
+[Constructor(DOMString type,
+ optional ExtendableEventInit eventInitDict),
+ Exposed=ServiceWorker,
+ Pref="dom.serviceworker.enabled"]
+interface ExtendableEvent : Event {
+ [Throws] void waitUntil(/*Promise<*/any/*>*/ f);
+};
+
+dictionary ExtendableEventInit : EventInit {
+ // Defined for the forward compatibility across the derived events
+};
diff --git a/components/script/dom/webidls/ExtendableMessageEvent.webidl b/components/script/dom/webidls/ExtendableMessageEvent.webidl
new file mode 100644
index 00000000000..4190757d1f2
--- /dev/null
+++ b/components/script/dom/webidls/ExtendableMessageEvent.webidl
@@ -0,0 +1,24 @@
+/* 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/. */
+
+// https://w3c.github.io/ServiceWorker/#extendablemessage-event-section
+
+[Constructor(DOMString type, optional ExtendableMessageEventInit eventInitDict),
+ Exposed=ServiceWorker,
+ Pref="dom.serviceworker.enabled"]
+interface ExtendableMessageEvent : ExtendableEvent {
+ readonly attribute any data;
+ readonly attribute DOMString origin;
+ readonly attribute DOMString lastEventId;
+ // [SameObject] readonly attribute (Client or ServiceWorker /*or MessagePort*/)? source;
+ // readonly attribute FrozenArray<MessagePort>? ports;
+};
+
+dictionary ExtendableMessageEventInit : ExtendableEventInit {
+ any data;
+ DOMString origin;
+ DOMString lastEventId;
+ // (Client or ServiceWorker /*or MessagePort*/)? source;
+ // sequence<MessagePort>? ports;
+};