Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1776)

Unified Diff: Source/modules/serviceworkers/ServiceWorkerMessageEvent.h

Issue 1130113006: ServiceWorker: Introduce ServiceWorkerMessageEvent to replace MessageEvent (3/3). (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: remove custom bindings Created 5 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: Source/modules/serviceworkers/ServiceWorkerMessageEvent.h
diff --git a/Source/modules/serviceworkers/ServiceWorkerMessageEvent.h b/Source/modules/serviceworkers/ServiceWorkerMessageEvent.h
new file mode 100644
index 0000000000000000000000000000000000000000..b37a5009e1280cf51f0b0ef81d377cf8a7dcf3f1
--- /dev/null
+++ b/Source/modules/serviceworkers/ServiceWorkerMessageEvent.h
@@ -0,0 +1,63 @@
+// Copyright 2015 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef ServiceWorkerMessageEvent_h
+#define ServiceWorkerMessageEvent_h
+
+#include "core/dom/DOMArrayBuffer.h"
+#include "core/dom/MessagePort.h"
+#include "modules/EventModules.h"
+#include "modules/ModulesExport.h"
+#include "modules/serviceworkers/ServiceWorkerMessageEventInit.h"
+
+namespace blink {
+
+class MODULES_EXPORT ServiceWorkerMessageEvent final : public Event {
+ DEFINE_WRAPPERTYPEINFO();
+public:
+ static PassRefPtrWillBeRawPtr<ServiceWorkerMessageEvent> create()
+ {
+ return adoptRefWillBeNoop(new ServiceWorkerMessageEvent);
+ }
+
+ static PassRefPtrWillBeRawPtr<ServiceWorkerMessageEvent> create(const AtomicString& type, const ServiceWorkerMessageEventInit& initializer)
+ {
+ return adoptRefWillBeNoop(new ServiceWorkerMessageEvent(type, initializer));
+ }
+
+ static PassRefPtrWillBeRawPtr<ServiceWorkerMessageEvent> create(PassOwnPtrWillBeRawPtr<MessagePortArray> ports, PassRefPtr<SerializedScriptValue> data, const ServiceWorkerOrMessagePort& source)
+ {
+ return adoptRefWillBeNoop(new ServiceWorkerMessageEvent(data, String(), String(), source, ports));
+ }
+
+ virtual ~ServiceWorkerMessageEvent();
+
+ const String& origin() const { return m_origin; }
+ const String& lastEventId() const { return m_lastEventId; }
+ MessagePortArray ports() const { return m_ports ? *m_ports : MessagePortArray(); }
+ void source(ServiceWorkerOrMessagePort& result) const { result = m_source; }
+
+ virtual const AtomicString& interfaceName() const override;
+
+ ScriptValue data() const { return m_data; }
+ SerializedScriptValue* serializedData() const { return m_serializedData.get(); }
bashi 2015/05/22 00:23:36 Could you explain why do you need this? The reaso
+
+ DECLARE_VIRTUAL_TRACE();
+
+private:
+ ServiceWorkerMessageEvent();
+ ServiceWorkerMessageEvent(const AtomicString& type, const ServiceWorkerMessageEventInit& initializer);
+ ServiceWorkerMessageEvent(PassRefPtr<SerializedScriptValue> data, const String& origin, const String& lastEventId, const ServiceWorkerOrMessagePort& source, PassOwnPtrWillBeRawPtr<MessagePortArray> ports);
+
+ ScriptValue m_data;
+ RefPtr<SerializedScriptValue> m_serializedData;
+ String m_origin;
+ String m_lastEventId;
+ ServiceWorkerOrMessagePort m_source;
+ OwnPtrWillBeMember<MessagePortArray> m_ports;
+};
+
+} // namespace blink
+
+#endif // ServiceWorkerMessageEvent_h

Powered by Google App Engine
This is Rietveld 408576698