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 |