| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "content/child/service_worker/web_service_worker_impl.h" | 5 #include "content/child/service_worker/web_service_worker_impl.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "base/macros.h" | 9 #include "base/macros.h" |
| 10 #include "base/memory/ptr_util.h" | 10 #include "base/memory/ptr_util.h" |
| (...skipping 25 matching lines...) Expand all Loading... |
| 36 ~HandleImpl() override {} | 36 ~HandleImpl() override {} |
| 37 | 37 |
| 38 blink::WebServiceWorker* serviceWorker() override { return worker_.get(); } | 38 blink::WebServiceWorker* serviceWorker() override { return worker_.get(); } |
| 39 | 39 |
| 40 private: | 40 private: |
| 41 scoped_refptr<WebServiceWorkerImpl> worker_; | 41 scoped_refptr<WebServiceWorkerImpl> worker_; |
| 42 | 42 |
| 43 DISALLOW_COPY_AND_ASSIGN(HandleImpl); | 43 DISALLOW_COPY_AND_ASSIGN(HandleImpl); |
| 44 }; | 44 }; |
| 45 | 45 |
| 46 void SendPostMessageToWorkerOnMainThread( | 46 void SendPostMessageToWorkerOnMainThread(ThreadSafeSender* thread_safe_sender, |
| 47 ThreadSafeSender* thread_safe_sender, | 47 int handle_id, |
| 48 int handle_id, | 48 int provider_id, |
| 49 int provider_id, | 49 const base::string16& message, |
| 50 const base::string16& message, | 50 const url::Origin& source_origin, |
| 51 const url::Origin& source_origin, | 51 WebMessagePortChannelArray channels) { |
| 52 std::unique_ptr<WebMessagePortChannelArray> channels) { | |
| 53 thread_safe_sender->Send(new ServiceWorkerHostMsg_PostMessageToWorker( | 52 thread_safe_sender->Send(new ServiceWorkerHostMsg_PostMessageToWorker( |
| 54 handle_id, provider_id, message, source_origin, | 53 handle_id, provider_id, message, source_origin, |
| 55 WebMessagePortChannelImpl::ExtractMessagePortIDs(std::move(channels)))); | 54 WebMessagePortChannelImpl::ExtractMessagePorts(std::move(channels)))); |
| 56 } | 55 } |
| 57 | 56 |
| 58 } // namespace | 57 } // namespace |
| 59 | 58 |
| 60 WebServiceWorkerImpl::WebServiceWorkerImpl( | 59 WebServiceWorkerImpl::WebServiceWorkerImpl( |
| 61 std::unique_ptr<ServiceWorkerHandleReference> handle_ref, | 60 std::unique_ptr<ServiceWorkerHandleReference> handle_ref, |
| 62 ThreadSafeSender* thread_safe_sender) | 61 ThreadSafeSender* thread_safe_sender) |
| 63 : handle_ref_(std::move(handle_ref)), | 62 : handle_ref_(std::move(handle_ref)), |
| 64 state_(handle_ref_->state()), | 63 state_(handle_ref_->state()), |
| 65 thread_safe_sender_(thread_safe_sender), | 64 thread_safe_sender_(thread_safe_sender), |
| (...skipping 28 matching lines...) Expand all Loading... |
| 94 } | 93 } |
| 95 | 94 |
| 96 blink::WebServiceWorkerState WebServiceWorkerImpl::state() const { | 95 blink::WebServiceWorkerState WebServiceWorkerImpl::state() const { |
| 97 return state_; | 96 return state_; |
| 98 } | 97 } |
| 99 | 98 |
| 100 void WebServiceWorkerImpl::postMessage( | 99 void WebServiceWorkerImpl::postMessage( |
| 101 blink::WebServiceWorkerProvider* provider, | 100 blink::WebServiceWorkerProvider* provider, |
| 102 const WebString& message, | 101 const WebString& message, |
| 103 const WebSecurityOrigin& source_origin, | 102 const WebSecurityOrigin& source_origin, |
| 104 WebMessagePortChannelArray* channels) { | 103 WebMessagePortChannelArray channels) { |
| 105 WebServiceWorkerProviderImpl* provider_impl = | 104 WebServiceWorkerProviderImpl* provider_impl = |
| 106 static_cast<WebServiceWorkerProviderImpl*>(provider); | 105 static_cast<WebServiceWorkerProviderImpl*>(provider); |
| 107 ServiceWorkerDispatcher* dispatcher = | 106 ServiceWorkerDispatcher* dispatcher = |
| 108 ServiceWorkerDispatcher::GetThreadSpecificInstance(); | 107 ServiceWorkerDispatcher::GetThreadSpecificInstance(); |
| 109 DCHECK(dispatcher); | 108 DCHECK(dispatcher); |
| 110 | 109 |
| 111 // This may send channels for MessagePorts, and all internal book-keeping | 110 // This may send channels for MessagePorts, and all internal book-keeping |
| 112 // messages for MessagePort (e.g. QueueMessages) are sent from main thread | 111 // messages for MessagePort (e.g. QueueMessages) are sent from main thread |
| 113 // (with thread hopping), so we need to do the same thread hopping here not | 112 // (with thread hopping), so we need to do the same thread hopping here not |
| 114 // to overtake those messages. | 113 // to overtake those messages. |
| 115 dispatcher->main_thread_task_runner()->PostTask( | 114 dispatcher->main_thread_task_runner()->PostTask( |
| 116 FROM_HERE, | 115 FROM_HERE, |
| 117 base::Bind(&SendPostMessageToWorkerOnMainThread, | 116 base::Bind(&SendPostMessageToWorkerOnMainThread, |
| 118 base::RetainedRef(thread_safe_sender_), | 117 base::RetainedRef(thread_safe_sender_), |
| 119 handle_ref_->handle_id(), provider_impl->provider_id(), | 118 handle_ref_->handle_id(), provider_impl->provider_id(), |
| 120 // We convert WebString to string16 before crossing | 119 // We convert WebString to string16 before crossing |
| 121 // threads for thread-safety. | 120 // threads for thread-safety. |
| 122 message.utf16(), url::Origin(source_origin), | 121 message.utf16(), url::Origin(source_origin), |
| 123 base::Passed(base::WrapUnique(channels)))); | 122 base::Passed(&channels))); |
| 124 } | 123 } |
| 125 | 124 |
| 126 void WebServiceWorkerImpl::terminate() { | 125 void WebServiceWorkerImpl::terminate() { |
| 127 thread_safe_sender_->Send( | 126 thread_safe_sender_->Send( |
| 128 new ServiceWorkerHostMsg_TerminateWorker(handle_ref_->handle_id())); | 127 new ServiceWorkerHostMsg_TerminateWorker(handle_ref_->handle_id())); |
| 129 } | 128 } |
| 130 | 129 |
| 131 // static | 130 // static |
| 132 std::unique_ptr<blink::WebServiceWorker::Handle> | 131 std::unique_ptr<blink::WebServiceWorker::Handle> |
| 133 WebServiceWorkerImpl::CreateHandle( | 132 WebServiceWorkerImpl::CreateHandle( |
| 134 const scoped_refptr<WebServiceWorkerImpl>& worker) { | 133 const scoped_refptr<WebServiceWorkerImpl>& worker) { |
| 135 if (!worker) | 134 if (!worker) |
| 136 return nullptr; | 135 return nullptr; |
| 137 return base::MakeUnique<HandleImpl>(worker); | 136 return base::MakeUnique<HandleImpl>(worker); |
| 138 } | 137 } |
| 139 | 138 |
| 140 WebServiceWorkerImpl::~WebServiceWorkerImpl() { | 139 WebServiceWorkerImpl::~WebServiceWorkerImpl() { |
| 141 ServiceWorkerDispatcher* dispatcher = | 140 ServiceWorkerDispatcher* dispatcher = |
| 142 ServiceWorkerDispatcher::GetThreadSpecificInstance(); | 141 ServiceWorkerDispatcher::GetThreadSpecificInstance(); |
| 143 if (dispatcher) | 142 if (dispatcher) |
| 144 dispatcher->RemoveServiceWorker(handle_ref_->handle_id()); | 143 dispatcher->RemoveServiceWorker(handle_ref_->handle_id()); |
| 145 } | 144 } |
| 146 | 145 |
| 147 } // namespace content | 146 } // namespace content |
| OLD | NEW |