Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (C) 2013 Google Inc. All rights reserved. | 2 * Copyright (C) 2013 Google Inc. All rights reserved. |
| 3 * | 3 * |
| 4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
| 5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
| 6 * met: | 6 * met: |
| 7 * | 7 * |
| 8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
| 9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
| 10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
| (...skipping 18 matching lines...) Expand all Loading... | |
| 29 */ | 29 */ |
| 30 | 30 |
| 31 #include "modules/serviceworkers/ServiceWorker.h" | 31 #include "modules/serviceworkers/ServiceWorker.h" |
| 32 | 32 |
| 33 #include "bindings/core/v8/ExceptionState.h" | 33 #include "bindings/core/v8/ExceptionState.h" |
| 34 #include "core/dom/ExceptionCode.h" | 34 #include "core/dom/ExceptionCode.h" |
| 35 #include "core/dom/MessagePort.h" | 35 #include "core/dom/MessagePort.h" |
| 36 #include "core/events/Event.h" | 36 #include "core/events/Event.h" |
| 37 #include "core/inspector/ConsoleMessage.h" | 37 #include "core/inspector/ConsoleMessage.h" |
| 38 #include "modules/EventTargetModules.h" | 38 #include "modules/EventTargetModules.h" |
| 39 #include "modules/serviceworkers/ServiceWorkerContainerClient.h" | |
| 39 #include "public/platform/WebMessagePortChannel.h" | 40 #include "public/platform/WebMessagePortChannel.h" |
| 40 #include "public/platform/WebString.h" | 41 #include "public/platform/WebString.h" |
| 41 #include "public/platform/modules/serviceworker/WebServiceWorkerState.h" | 42 #include "public/platform/modules/serviceworker/WebServiceWorkerState.h" |
| 42 | 43 |
| 43 namespace blink { | 44 namespace blink { |
| 44 | 45 |
| 45 const AtomicString& ServiceWorker::interfaceName() const | 46 const AtomicString& ServiceWorker::interfaceName() const |
| 46 { | 47 { |
| 47 return EventTargetNames::ServiceWorker; | 48 return EventTargetNames::ServiceWorker; |
| 48 } | 49 } |
| 49 | 50 |
| 50 void ServiceWorker::postMessage(ExecutionContext* context, PassRefPtr<Serialized ScriptValue> message, const MessagePortArray* ports, ExceptionState& exceptionSt ate) | 51 void ServiceWorker::postMessage(ExecutionContext* context, PassRefPtr<Serialized ScriptValue> message, const MessagePortArray* ports, ExceptionState& exceptionSt ate) |
| 51 { | 52 { |
| 53 if (!m_provider) { | |
| 54 exceptionState.throwDOMException(InvalidStateError, "Failed to post a me ssage: No associated provider is available."); | |
| 55 return; | |
| 56 } | |
|
falken
2016/03/02 09:02:48
Instead of keeping track of m_provider, would it b
nhiroki
2016/03/02 09:57:12
Good point. Changed!
| |
| 57 | |
| 52 // Disentangle the port in preparation for sending it to the remote context. | 58 // Disentangle the port in preparation for sending it to the remote context. |
| 53 OwnPtr<MessagePortChannelArray> channels = MessagePort::disentanglePorts(con text, ports, exceptionState); | 59 OwnPtr<MessagePortChannelArray> channels = MessagePort::disentanglePorts(con text, ports, exceptionState); |
| 54 if (exceptionState.hadException()) | 60 if (exceptionState.hadException()) |
| 55 return; | 61 return; |
| 56 if (m_handle->serviceWorker()->state() == WebServiceWorkerStateRedundant) { | 62 if (m_handle->serviceWorker()->state() == WebServiceWorkerStateRedundant) { |
| 57 exceptionState.throwDOMException(InvalidStateError, "ServiceWorker is in redundant state."); | 63 exceptionState.throwDOMException(InvalidStateError, "ServiceWorker is in redundant state."); |
| 58 return; | 64 return; |
| 59 } | 65 } |
| 60 | 66 |
| 61 if (message->containsTransferableArrayBuffer()) | 67 if (message->containsTransferableArrayBuffer()) |
| 62 context->addConsoleMessage(ConsoleMessage::create(JSMessageSource, Warni ngMessageLevel, "ServiceWorker cannot send an ArrayBuffer as a transferable obje ct yet. See http://crbug.com/511119")); | 68 context->addConsoleMessage(ConsoleMessage::create(JSMessageSource, Warni ngMessageLevel, "ServiceWorker cannot send an ArrayBuffer as a transferable obje ct yet. See http://crbug.com/511119")); |
| 63 | 69 |
| 64 WebString messageString = message->toWireString(); | 70 WebString messageString = message->toWireString(); |
| 65 OwnPtr<WebMessagePortChannelArray> webChannels = MessagePort::toWebMessagePo rtChannelArray(channels.release()); | 71 OwnPtr<WebMessagePortChannelArray> webChannels = MessagePort::toWebMessagePo rtChannelArray(channels.release()); |
| 66 m_handle->serviceWorker()->postMessage(messageString, webChannels.leakPtr()) ; | 72 m_handle->serviceWorker()->postMessage(m_provider, messageString, webChannel s.leakPtr()); |
| 67 } | 73 } |
| 68 | 74 |
| 69 void ServiceWorker::internalsTerminate() | 75 void ServiceWorker::internalsTerminate() |
| 70 { | 76 { |
| 71 m_handle->serviceWorker()->terminate(); | 77 m_handle->serviceWorker()->terminate(); |
| 72 } | 78 } |
| 73 | 79 |
| 74 void ServiceWorker::dispatchStateChangeEvent() | 80 void ServiceWorker::dispatchStateChangeEvent() |
| 75 { | 81 { |
| 76 this->dispatchEvent(Event::create(EventTypeNames::statechange)); | 82 this->dispatchEvent(Event::create(EventTypeNames::statechange)); |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 109 return getOrCreate(executionContext, handle); | 115 return getOrCreate(executionContext, handle); |
| 110 } | 116 } |
| 111 | 117 |
| 112 bool ServiceWorker::hasPendingActivity() const | 118 bool ServiceWorker::hasPendingActivity() const |
| 113 { | 119 { |
| 114 if (!executionContext()) | 120 if (!executionContext()) |
| 115 return false; | 121 return false; |
| 116 return m_handle->serviceWorker()->state() != WebServiceWorkerStateRedundant; | 122 return m_handle->serviceWorker()->state() != WebServiceWorkerStateRedundant; |
| 117 } | 123 } |
| 118 | 124 |
| 125 void ServiceWorker::contextDestroyed() | |
| 126 { | |
| 127 m_provider = nullptr; | |
| 128 } | |
| 129 | |
| 119 ServiceWorker* ServiceWorker::getOrCreate(ExecutionContext* executionContext, Pa ssOwnPtr<WebServiceWorker::Handle> handle) | 130 ServiceWorker* ServiceWorker::getOrCreate(ExecutionContext* executionContext, Pa ssOwnPtr<WebServiceWorker::Handle> handle) |
| 120 { | 131 { |
| 121 if (!handle) | 132 if (!handle) |
| 122 return nullptr; | 133 return nullptr; |
| 123 | 134 |
| 124 ServiceWorker* existingWorker = static_cast<ServiceWorker*>(handle->serviceW orker()->proxy()); | 135 ServiceWorker* existingWorker = static_cast<ServiceWorker*>(handle->serviceW orker()->proxy()); |
| 125 if (existingWorker) { | 136 if (existingWorker) { |
| 126 ASSERT(existingWorker->executionContext() == executionContext); | 137 ASSERT(existingWorker->executionContext() == executionContext); |
| 127 return existingWorker; | 138 return existingWorker; |
| 128 } | 139 } |
| 129 | 140 |
| 130 return new ServiceWorker(executionContext, handle); | 141 return new ServiceWorker(executionContext, handle); |
| 131 } | 142 } |
| 132 | 143 |
| 133 ServiceWorker::ServiceWorker(ExecutionContext* executionContext, PassOwnPtr<WebS erviceWorker::Handle> handle) | 144 ServiceWorker::ServiceWorker(ExecutionContext* executionContext, PassOwnPtr<WebS erviceWorker::Handle> handle) |
| 134 : AbstractWorker(executionContext) | 145 : AbstractWorker(executionContext) |
| 135 , m_handle(handle) | 146 , m_handle(handle) |
| 147 , m_provider(nullptr) | |
| 136 { | 148 { |
| 137 ASSERT(m_handle); | 149 ASSERT(m_handle); |
| 150 | |
| 151 if (ServiceWorkerContainerClient* client = ServiceWorkerContainerClient::fro m(executionContext)) | |
| 152 m_provider = client->provider(); | |
| 138 m_handle->serviceWorker()->setProxy(this); | 153 m_handle->serviceWorker()->setProxy(this); |
| 139 } | 154 } |
| 140 | 155 |
| 141 ServiceWorker::~ServiceWorker() | 156 ServiceWorker::~ServiceWorker() |
| 142 { | 157 { |
| 143 } | 158 } |
| 144 | 159 |
| 145 } // namespace blink | 160 } // namespace blink |
| OLD | NEW |