Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(359)

Side by Side Diff: content/renderer/service_worker/embedded_worker_dispatcher.cc

Issue 2637743002: ServiceWorker: remove EmbeddedWorkerMsg_StartWorker (Closed)
Patch Set: Removed unnecessary includes and codes Created 3 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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
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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698