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

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

Issue 2378073002: Reland of ServiceWorker: Implement StartWorker by using mojo (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 2 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 8
9 #include "base/metrics/histogram_macros.h" 9 #include "base/metrics/histogram_macros.h"
10 #include "base/strings/string16.h" 10 #include "base/strings/string16.h"
11 #include "base/strings/utf_string_conversions.h" 11 #include "base/strings/utf_string_conversions.h"
12 #include "content/child/child_process.h" 12 #include "content/child/child_process.h"
13 #include "content/child/scoped_child_process_reference.h"
14 #include "content/child/thread_safe_sender.h" 13 #include "content/child/thread_safe_sender.h"
15 #include "content/child/worker_thread_registry.h" 14 #include "content/child/worker_thread_registry.h"
16 #include "content/common/devtools_messages.h" 15 #include "content/common/devtools_messages.h"
17 #include "content/common/service_worker/embedded_worker_messages.h" 16 #include "content/common/service_worker/embedded_worker_messages.h"
18 #include "content/public/common/content_client.h" 17 #include "content/public/common/content_client.h"
19 #include "content/renderer/render_thread_impl.h" 18 #include "content/renderer/render_thread_impl.h"
20 #include "content/renderer/service_worker/embedded_worker_devtools_agent.h" 19 #include "content/renderer/service_worker/embedded_worker_devtools_agent.h"
21 #include "content/renderer/service_worker/service_worker_context_client.h" 20 #include "content/renderer/service_worker/service_worker_context_client.h"
22 #include "third_party/WebKit/public/platform/WebString.h" 21 #include "third_party/WebKit/public/platform/WebString.h"
23 #include "third_party/WebKit/public/platform/WebURL.h" 22 #include "third_party/WebKit/public/platform/WebURL.h"
24 #include "third_party/WebKit/public/web/WebConsoleMessage.h" 23 #include "third_party/WebKit/public/web/WebConsoleMessage.h"
25 #include "third_party/WebKit/public/web/WebEmbeddedWorker.h" 24 #include "third_party/WebKit/public/web/WebEmbeddedWorker.h"
26 #include "third_party/WebKit/public/web/WebEmbeddedWorkerStartData.h" 25 #include "third_party/WebKit/public/web/WebEmbeddedWorkerStartData.h"
27 26
28 namespace content { 27 namespace content {
29 28
30 // A thin wrapper of WebEmbeddedWorker which also adds and releases process 29 EmbeddedWorkerDispatcher::WorkerWrapper::WorkerWrapper(
31 // references automatically. 30 blink::WebEmbeddedWorker* worker,
32 class EmbeddedWorkerDispatcher::WorkerWrapper { 31 int devtools_agent_route_id)
33 public: 32 : worker_(worker),
34 WorkerWrapper(blink::WebEmbeddedWorker* worker, int devtools_agent_route_id) 33 dev_tools_agent_(
35 : worker_(worker), 34 new EmbeddedWorkerDevToolsAgent(worker, devtools_agent_route_id)) {}
36 dev_tools_agent_(
37 new EmbeddedWorkerDevToolsAgent(worker, devtools_agent_route_id)) {}
38 ~WorkerWrapper() {}
39 35
40 blink::WebEmbeddedWorker* worker() { return worker_.get(); } 36 EmbeddedWorkerDispatcher::WorkerWrapper::~WorkerWrapper() {}
41
42 private:
43 ScopedChildProcessReference process_ref_;
44 std::unique_ptr<blink::WebEmbeddedWorker> worker_;
45 std::unique_ptr<EmbeddedWorkerDevToolsAgent> dev_tools_agent_;
46 };
47 37
48 EmbeddedWorkerDispatcher::EmbeddedWorkerDispatcher() : weak_factory_(this) {} 38 EmbeddedWorkerDispatcher::EmbeddedWorkerDispatcher() : weak_factory_(this) {}
49 39
50 EmbeddedWorkerDispatcher::~EmbeddedWorkerDispatcher() {} 40 EmbeddedWorkerDispatcher::~EmbeddedWorkerDispatcher() {}
51 41
52 bool EmbeddedWorkerDispatcher::OnMessageReceived( 42 bool EmbeddedWorkerDispatcher::OnMessageReceived(
53 const IPC::Message& message) { 43 const IPC::Message& message) {
54 bool handled = true; 44 bool handled = true;
55 IPC_BEGIN_MESSAGE_MAP(EmbeddedWorkerDispatcher, message) 45 IPC_BEGIN_MESSAGE_MAP(EmbeddedWorkerDispatcher, message)
56 IPC_MESSAGE_HANDLER(EmbeddedWorkerMsg_StartWorker, OnStartWorker) 46 IPC_MESSAGE_HANDLER(EmbeddedWorkerMsg_StartWorker, OnStartWorker)
(...skipping 15 matching lines...) Expand all
72 base::TimeTicks::Now() - stop_time); 62 base::TimeTicks::Now() - stop_time);
73 stop_worker_times_.erase(embedded_worker_id); 63 stop_worker_times_.erase(embedded_worker_id);
74 } 64 }
75 65
76 RenderThreadImpl::current()->thread_safe_sender()->Send( 66 RenderThreadImpl::current()->thread_safe_sender()->Send(
77 new EmbeddedWorkerHostMsg_WorkerStopped(embedded_worker_id)); 67 new EmbeddedWorkerHostMsg_WorkerStopped(embedded_worker_id));
78 workers_.Remove(embedded_worker_id); 68 workers_.Remove(embedded_worker_id);
79 } 69 }
80 70
81 void EmbeddedWorkerDispatcher::OnStartWorker( 71 void EmbeddedWorkerDispatcher::OnStartWorker(
82 const EmbeddedWorkerMsg_StartWorker_Params& params) { 72 const EmbeddedWorkerStartParams& params) {
83 DCHECK(!workers_.Lookup(params.embedded_worker_id)); 73 DCHECK(!workers_.Lookup(params.embedded_worker_id));
84 TRACE_EVENT0("ServiceWorker", "EmbeddedWorkerDispatcher::OnStartWorker"); 74 TRACE_EVENT0("ServiceWorker", "EmbeddedWorkerDispatcher::OnStartWorker");
85 std::unique_ptr<WorkerWrapper> wrapper(new WorkerWrapper( 75 std::unique_ptr<WorkerWrapper> wrapper = StartWorkerContext(
86 blink::WebEmbeddedWorker::create( 76 params, base::MakeUnique<ServiceWorkerContextClient>(
87 new ServiceWorkerContextClient(params.embedded_worker_id, 77 params.embedded_worker_id, params.service_worker_version_id,
88 params.service_worker_version_id, 78 params.scope, params.script_url,
89 params.scope, params.script_url, 79 params.worker_devtools_agent_route_id));
90 params.worker_devtools_agent_route_id), 80 RegisterWorker(params.embedded_worker_id, std::move(wrapper));
91 NULL),
92 params.worker_devtools_agent_route_id));
93
94 blink::WebEmbeddedWorkerStartData start_data;
95 start_data.scriptURL = params.script_url;
96 start_data.userAgent = base::UTF8ToUTF16(GetContentClient()->GetUserAgent());
97 start_data.waitForDebuggerMode =
98 params.wait_for_debugger ?
99 blink::WebEmbeddedWorkerStartData::WaitForDebugger :
100 blink::WebEmbeddedWorkerStartData::DontWaitForDebugger;
101 start_data.v8CacheOptions = static_cast<blink::WebSettings::V8CacheOptions>(
102 params.settings.v8_cache_options);
103 start_data.dataSaverEnabled = params.settings.data_saver_enabled;
104 start_data.pauseAfterDownloadMode =
105 params.pause_after_download
106 ? blink::WebEmbeddedWorkerStartData::PauseAfterDownload
107 : blink::WebEmbeddedWorkerStartData::DontPauseAfterDownload;
108
109 wrapper->worker()->startWorkerContext(start_data);
110 workers_.AddWithID(wrapper.release(), params.embedded_worker_id);
111 } 81 }
112 82
113 void EmbeddedWorkerDispatcher::OnStopWorker(int embedded_worker_id) { 83 void EmbeddedWorkerDispatcher::OnStopWorker(int embedded_worker_id) {
114 TRACE_EVENT0("ServiceWorker", "EmbeddedWorkerDispatcher::OnStopWorker"); 84 TRACE_EVENT0("ServiceWorker", "EmbeddedWorkerDispatcher::OnStopWorker");
115 WorkerWrapper* wrapper = workers_.Lookup(embedded_worker_id); 85 WorkerWrapper* wrapper = workers_.Lookup(embedded_worker_id);
116 if (!wrapper) { 86 if (!wrapper) {
117 LOG(WARNING) << "Got OnStopWorker for nonexistent worker"; 87 LOG(WARNING) << "Got OnStopWorker for nonexistent worker";
118 return; 88 return;
119 } 89 }
120 90
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after
156 target_level = blink::WebConsoleMessage::LevelWarning; 126 target_level = blink::WebConsoleMessage::LevelWarning;
157 break; 127 break;
158 case CONSOLE_MESSAGE_LEVEL_ERROR: 128 case CONSOLE_MESSAGE_LEVEL_ERROR:
159 target_level = blink::WebConsoleMessage::LevelError; 129 target_level = blink::WebConsoleMessage::LevelError;
160 break; 130 break;
161 } 131 }
162 wrapper->worker()->addMessageToConsole(blink::WebConsoleMessage( 132 wrapper->worker()->addMessageToConsole(blink::WebConsoleMessage(
163 target_level, blink::WebString::fromUTF8(message))); 133 target_level, blink::WebString::fromUTF8(message)));
164 } 134 }
165 135
136 std::unique_ptr<EmbeddedWorkerDispatcher::WorkerWrapper>
137 EmbeddedWorkerDispatcher::StartWorkerContext(
138 const EmbeddedWorkerStartParams& params,
139 std::unique_ptr<ServiceWorkerContextClient> context_client) {
140 std::unique_ptr<WorkerWrapper> wrapper(new WorkerWrapper(
141 blink::WebEmbeddedWorker::create(context_client.release(), nullptr),
142 params.worker_devtools_agent_route_id));
143
144 blink::WebEmbeddedWorkerStartData start_data;
145 start_data.scriptURL = params.script_url;
146 start_data.userAgent = base::UTF8ToUTF16(GetContentClient()->GetUserAgent());
147 start_data.waitForDebuggerMode =
148 params.wait_for_debugger
149 ? blink::WebEmbeddedWorkerStartData::WaitForDebugger
150 : blink::WebEmbeddedWorkerStartData::DontWaitForDebugger;
151 start_data.v8CacheOptions = static_cast<blink::WebSettings::V8CacheOptions>(
152 params.settings.v8_cache_options);
153 start_data.dataSaverEnabled = params.settings.data_saver_enabled;
154 start_data.pauseAfterDownloadMode =
155 params.pause_after_download
156 ? blink::WebEmbeddedWorkerStartData::PauseAfterDownload
157 : blink::WebEmbeddedWorkerStartData::DontPauseAfterDownload;
158
159 wrapper->worker()->startWorkerContext(start_data);
160 return wrapper;
161 }
162
163 void EmbeddedWorkerDispatcher::RegisterWorker(
164 int embedded_worker_id,
165 std::unique_ptr<WorkerWrapper> wrapper) {
166 workers_.AddWithID(wrapper.release(), embedded_worker_id);
167 }
168
166 } // namespace content 169 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698