Chromium Code Reviews| Index: third_party/WebKit/Source/modules/serviceworkers/ExtendableMessageEvent.cpp |
| diff --git a/third_party/WebKit/Source/modules/serviceworkers/ExtendableMessageEvent.cpp b/third_party/WebKit/Source/modules/serviceworkers/ExtendableMessageEvent.cpp |
| index af432454b2338853b614dddda8163e90533ee65f..473416bcc47b9907f826c4981805d09d6ba62fc2 100644 |
| --- a/third_party/WebKit/Source/modules/serviceworkers/ExtendableMessageEvent.cpp |
| +++ b/third_party/WebKit/Source/modules/serviceworkers/ExtendableMessageEvent.cpp |
| @@ -21,6 +21,37 @@ PassRefPtrWillBeRawPtr<ExtendableMessageEvent> ExtendableMessageEvent::create(co |
| return adoptRefWillBeNoop(new ExtendableMessageEvent(type, initializer, observer)); |
| } |
| +PassRefPtrWillBeRawPtr<ExtendableMessageEvent> ExtendableMessageEvent::create(PassRefPtr<SerializedScriptValue> data, const String& origin, PassOwnPtrWillBeRawPtr<MessagePortArray> ports, WaitUntilObserver* observer) |
| +{ |
| + return adoptRefWillBeNoop(new ExtendableMessageEvent(data, origin, ports, observer)); |
| +} |
| + |
| +MessagePortArray ExtendableMessageEvent::ports(bool& isNull) const |
| +{ |
| + if (m_ports) { |
| + isNull = false; |
| + return *m_ports; |
| + } |
| + isNull = false; |
| + return MessagePortArray(); |
| +} |
| + |
| +MessagePortArray ExtendableMessageEvent::ports() const |
| +{ |
| + bool unused; |
| + return ports(unused); |
| +} |
|
falken
2016/02/05 02:28:52
Ah, I see the ports() code came from MessageEvent.
nhiroki
2016/02/05 09:15:37
Done (Just copied the comment from MessageEvent.cp
falken
2016/02/05 09:58:18
OK with me. I also noticed the snippet is in Servi
nhiroki
2016/02/09 10:20:03
Done.
|
| + |
| +void ExtendableMessageEvent::source(ClientOrServiceWorkerOrMessagePort& result) const |
| +{ |
| + if (m_sourceAsClient) |
| + result = ClientOrServiceWorkerOrMessagePort::fromClient(m_sourceAsClient); |
| + else if (m_sourceAsServiceWorker) |
| + result = ClientOrServiceWorkerOrMessagePort::fromServiceWorker(m_sourceAsServiceWorker); |
| + else if (m_sourceAsMessagePort) |
| + result = ClientOrServiceWorkerOrMessagePort::fromMessagePort(m_sourceAsMessagePort); |
|
falken
2016/02/05 02:28:52
else NOTREACHED?
nhiroki
2016/02/05 09:15:37
I think the case actually happens when the event i
falken
2016/02/05 09:58:18
Hm, I'm not sure how the bindings works but I'm wo
nhiroki
2016/02/09 10:20:03
According to the spec, null is the expected value:
|
| +} |
| + |
| const AtomicString& ExtendableMessageEvent::interfaceName() const |
| { |
| return EventNames::ExtendableMessageEvent; |
| @@ -28,6 +59,10 @@ const AtomicString& ExtendableMessageEvent::interfaceName() const |
| DEFINE_TRACE(ExtendableMessageEvent) |
| { |
| + visitor->trace(m_sourceAsClient); |
| + visitor->trace(m_sourceAsServiceWorker); |
| + visitor->trace(m_sourceAsMessagePort); |
| + visitor->trace(m_ports); |
| ExtendableEvent::trace(visitor); |
| } |
| @@ -43,7 +78,31 @@ ExtendableMessageEvent::ExtendableMessageEvent(const AtomicString& type, const E |
| ExtendableMessageEvent::ExtendableMessageEvent(const AtomicString& type, const ExtendableMessageEventInit& initializer, WaitUntilObserver* observer) |
| : ExtendableEvent(type, initializer, observer) |
| { |
| - // TODO(nhiroki): Set attributes (crbug.com/543198). |
| + if (initializer.hasData()) |
| + m_data = initializer.data(); |
| + if (initializer.hasOrigin()) |
| + m_origin = initializer.origin(); |
| + if (initializer.hasSource()) { |
| + if (initializer.source().isClient()) |
| + m_sourceAsClient = initializer.source().getAsClient(); |
| + else if (initializer.source().isServiceWorker()) |
| + m_sourceAsServiceWorker = initializer.source().getAsServiceWorker(); |
| + else if (initializer.source().isMessagePort()) |
| + m_sourceAsMessagePort = initializer.source().getAsMessagePort(); |
| + } |
| + if (initializer.hasPorts()) |
| + m_ports = adoptRefWillBeNoop(new MessagePortArray(initializer.ports())); |
| +} |
| + |
| +ExtendableMessageEvent::ExtendableMessageEvent(PassRefPtr<SerializedScriptValue> data, const String& origin, PassOwnPtrWillBeRawPtr<MessagePortArray> ports, WaitUntilObserver* observer) |
| + : ExtendableEvent(EventTypeNames::message, ExtendableMessageEventInit(), observer) |
| + , m_serializedData(data) |
| + , m_origin(origin) |
| + , m_lastEventId(String()) |
| + , m_ports(ports) |
| +{ |
| + if (m_serializedData) |
| + m_serializedData->registerMemoryAllocatedWithCurrentScriptContext(); |
| } |
| } // namespace blink |