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 RegisterWorker(params.embedded_worker_id, std::move(wrapper)); | |
76 } | |
77 | |
78 void EmbeddedWorkerDispatcher::OnStopWorker(int embedded_worker_id) { | 66 void EmbeddedWorkerDispatcher::OnStopWorker(int embedded_worker_id) { |
79 TRACE_EVENT0("ServiceWorker", "EmbeddedWorkerDispatcher::OnStopWorker"); | 67 TRACE_EVENT0("ServiceWorker", "EmbeddedWorkerDispatcher::OnStopWorker"); |
80 WorkerWrapper* wrapper = workers_.Lookup(embedded_worker_id); | 68 WorkerWrapper* wrapper = workers_.Lookup(embedded_worker_id); |
81 // OnStopWorker is possible to be called twice. | 69 // OnStopWorker is possible to be called twice. |
82 if (!wrapper) { | 70 if (!wrapper) { |
83 LOG(WARNING) << "Got OnStopWorker for nonexistent worker"; | 71 LOG(WARNING) << "Got OnStopWorker for nonexistent worker"; |
84 return; | 72 return; |
85 } | 73 } |
86 // This should eventually call WorkerContextDestroyed. (We may need to post | 74 // This should eventually call WorkerContextDestroyed. (We may need to post |
87 // 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... |
175 void EmbeddedWorkerDispatcher::RecordStopWorkerTimer(int embedded_worker_id) { | 163 void EmbeddedWorkerDispatcher::RecordStopWorkerTimer(int embedded_worker_id) { |
176 WorkerWrapper* wrapper = workers_.Lookup(embedded_worker_id); | 164 WorkerWrapper* wrapper = workers_.Lookup(embedded_worker_id); |
177 DCHECK(wrapper); | 165 DCHECK(wrapper); |
178 // This should eventually call WorkerContextDestroyed. (We may need to post | 166 // This should eventually call WorkerContextDestroyed. (We may need to post |
179 // 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 |
180 // necessary) | 168 // necessary) |
181 stop_worker_times_[embedded_worker_id] = base::TimeTicks::Now(); | 169 stop_worker_times_[embedded_worker_id] = base::TimeTicks::Now(); |
182 } | 170 } |
183 | 171 |
184 } // namespace content | 172 } // namespace content |
OLD | NEW |