Chromium Code Reviews| 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..983b75a414eefdb7d97c5fe0b00c8900d37011eb |
| --- /dev/null |
| +++ b/Source/modules/serviceworkers/ServiceWorkerMessageEvent.h |
| @@ -0,0 +1,64 @@ |
| +// 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, PassRefPtrWillBeRawPtr<ServiceWorker> 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; |
| + |
| + virtual const AtomicString& interfaceName() const override; |
| + |
| + ScriptValue data() const { return m_data; } |
| + SerializedScriptValue* serializedData() const { return m_serializedData.get(); } |
| + |
| + DECLARE_VIRTUAL_TRACE(); |
| + |
| +private: |
| + ServiceWorkerMessageEvent(); |
| + ServiceWorkerMessageEvent(const AtomicString& type, const ServiceWorkerMessageEventInit& initializer); |
| + ServiceWorkerMessageEvent(PassRefPtr<SerializedScriptValue> data, const String& origin, const String& lastEventId, PassRefPtrWillBeRawPtr<ServiceWorker> source, PassOwnPtrWillBeRawPtr<MessagePortArray> ports); |
| + |
| + ScriptValue m_data; |
|
haraken
2015/06/25 04:18:49
This will cause a memory leak in some artificial s
|
| + RefPtr<SerializedScriptValue> m_serializedData; |
| + String m_origin; |
| + String m_lastEventId; |
| + RefPtrWillBeMember<ServiceWorker> m_sourceAsServiceWorker; |
| + RefPtrWillBeMember<MessagePort> m_sourceAsMessagePort; |
| + OwnPtrWillBeMember<MessagePortArray> m_ports; |
| +}; |
| + |
| +} // namespace blink |
| + |
| +#endif // ServiceWorkerMessageEvent_h |