| 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/renderer/service_worker/embedded_worker_dispatcher.h" | 5 #include "content/renderer/service_worker/embedded_worker_dispatcher.h" |
| 6 | 6 |
| 7 #include <memory> | 7 #include <memory> |
| 8 #include <utility> | 8 #include <utility> |
| 9 | 9 |
| 10 #include "base/memory/ptr_util.h" | 10 #include "base/memory/ptr_util.h" |
| (...skipping 28 matching lines...) Expand all Loading... |
| 39 EmbeddedWorkerDispatcher::WorkerWrapper::~WorkerWrapper() {} | 39 EmbeddedWorkerDispatcher::WorkerWrapper::~WorkerWrapper() {} |
| 40 | 40 |
| 41 EmbeddedWorkerDispatcher::EmbeddedWorkerDispatcher() : weak_factory_(this) {} | 41 EmbeddedWorkerDispatcher::EmbeddedWorkerDispatcher() : weak_factory_(this) {} |
| 42 | 42 |
| 43 EmbeddedWorkerDispatcher::~EmbeddedWorkerDispatcher() {} | 43 EmbeddedWorkerDispatcher::~EmbeddedWorkerDispatcher() {} |
| 44 | 44 |
| 45 bool EmbeddedWorkerDispatcher::OnMessageReceived( | 45 bool EmbeddedWorkerDispatcher::OnMessageReceived( |
| 46 const IPC::Message& message) { | 46 const IPC::Message& message) { |
| 47 bool handled = true; | 47 bool handled = true; |
| 48 IPC_BEGIN_MESSAGE_MAP(EmbeddedWorkerDispatcher, message) | 48 IPC_BEGIN_MESSAGE_MAP(EmbeddedWorkerDispatcher, message) |
| 49 IPC_MESSAGE_HANDLER(EmbeddedWorkerMsg_StartWorker, OnStartWorker) | |
| 50 IPC_MESSAGE_HANDLER(EmbeddedWorkerMsg_StopWorker, OnStopWorker) | 49 IPC_MESSAGE_HANDLER(EmbeddedWorkerMsg_StopWorker, OnStopWorker) |
| 51 IPC_MESSAGE_HANDLER(EmbeddedWorkerMsg_ResumeAfterDownload, | 50 IPC_MESSAGE_HANDLER(EmbeddedWorkerMsg_ResumeAfterDownload, |
| 52 OnResumeAfterDownload) | 51 OnResumeAfterDownload) |
| 53 IPC_MESSAGE_HANDLER(EmbeddedWorkerMsg_AddMessageToConsole, | 52 IPC_MESSAGE_HANDLER(EmbeddedWorkerMsg_AddMessageToConsole, |
| 54 OnAddMessageToConsole) | 53 OnAddMessageToConsole) |
| 55 IPC_MESSAGE_UNHANDLED(handled = false) | 54 IPC_MESSAGE_UNHANDLED(handled = false) |
| 56 IPC_END_MESSAGE_MAP() | 55 IPC_END_MESSAGE_MAP() |
| 57 return handled; | 56 return handled; |
| 58 } | 57 } |
| 59 | 58 |
| 60 void EmbeddedWorkerDispatcher::WorkerContextDestroyed( | 59 void EmbeddedWorkerDispatcher::WorkerContextDestroyed( |
| 61 int embedded_worker_id) { | 60 int embedded_worker_id) { |
| 62 RenderThreadImpl::current()->thread_safe_sender()->Send( | 61 RenderThreadImpl::current()->thread_safe_sender()->Send( |
| 63 new EmbeddedWorkerHostMsg_WorkerStopped(embedded_worker_id)); | 62 new EmbeddedWorkerHostMsg_WorkerStopped(embedded_worker_id)); |
| 64 UnregisterWorker(embedded_worker_id); | 63 UnregisterWorker(embedded_worker_id); |
| 65 } | 64 } |
| 66 | 65 |
| 67 void EmbeddedWorkerDispatcher::OnStartWorker( | |
| 68 const EmbeddedWorkerStartParams& params) { | |
| 69 DCHECK(!workers_.Lookup(params.embedded_worker_id)); | |
| 70 TRACE_EVENT0("ServiceWorker", "EmbeddedWorkerDispatcher::OnStartWorker"); | |
| 71 std::unique_ptr<WorkerWrapper> wrapper = StartWorkerContext( | |
| 72 params, base::MakeUnique<ServiceWorkerContextClient>( | |
| 73 params.embedded_worker_id, params.service_worker_version_id, | |
| 74 params.scope, params.script_url, | |
| 75 params.worker_devtools_agent_route_id)); | |
| 76 RegisterWorker(params.embedded_worker_id, std::move(wrapper)); | |
| 77 } | |
| 78 | |
| 79 void EmbeddedWorkerDispatcher::OnStopWorker(int embedded_worker_id) { | 66 void EmbeddedWorkerDispatcher::OnStopWorker(int embedded_worker_id) { |
| 80 TRACE_EVENT0("ServiceWorker", "EmbeddedWorkerDispatcher::OnStopWorker"); | 67 TRACE_EVENT0("ServiceWorker", "EmbeddedWorkerDispatcher::OnStopWorker"); |
| 81 WorkerWrapper* wrapper = workers_.Lookup(embedded_worker_id); | 68 WorkerWrapper* wrapper = workers_.Lookup(embedded_worker_id); |
| 82 // OnStopWorker is possible to be called twice. | 69 // OnStopWorker is possible to be called twice. |
| 83 if (!wrapper) { | 70 if (!wrapper) { |
| 84 LOG(WARNING) << "Got OnStopWorker for nonexistent worker"; | 71 LOG(WARNING) << "Got OnStopWorker for nonexistent worker"; |
| 85 return; | 72 return; |
| 86 } | 73 } |
| 87 // This should eventually call WorkerContextDestroyed. (We may need to post | 74 // This should eventually call WorkerContextDestroyed. (We may need to post |
| 88 // a delayed task to forcibly abort the worker context if we find it | 75 // a delayed task to forcibly abort the worker context if we find it |
| (...skipping 87 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 176 void EmbeddedWorkerDispatcher::RecordStopWorkerTimer(int embedded_worker_id) { | 163 void EmbeddedWorkerDispatcher::RecordStopWorkerTimer(int embedded_worker_id) { |
| 177 WorkerWrapper* wrapper = workers_.Lookup(embedded_worker_id); | 164 WorkerWrapper* wrapper = workers_.Lookup(embedded_worker_id); |
| 178 DCHECK(wrapper); | 165 DCHECK(wrapper); |
| 179 // This should eventually call WorkerContextDestroyed. (We may need to post | 166 // This should eventually call WorkerContextDestroyed. (We may need to post |
| 180 // a delayed task to forcibly abort the worker context if we find it | 167 // a delayed task to forcibly abort the worker context if we find it |
| 181 // necessary) | 168 // necessary) |
| 182 stop_worker_times_[embedded_worker_id] = base::TimeTicks::Now(); | 169 stop_worker_times_[embedded_worker_id] = base::TimeTicks::Now(); |
| 183 } | 170 } |
| 184 | 171 |
| 185 } // namespace content | 172 } // namespace content |
| OLD | NEW |