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

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

Issue 140893002: Adding slightly clearer separation between SW and EmbeddedWorker (still incomplete) (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: nit fixes Created 6 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 | Annotate | Revision Log
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_context_client.h" 5 #include "content/renderer/service_worker/embedded_worker_context_client.h"
6 6
7 #include "base/lazy_instance.h" 7 #include "base/lazy_instance.h"
8 #include "base/message_loop/message_loop_proxy.h" 8 #include "base/message_loop/message_loop_proxy.h"
9 #include "base/pickle.h" 9 #include "base/pickle.h"
10 #include "base/threading/thread_local.h" 10 #include "base/threading/thread_local.h"
11 #include "content/child/thread_safe_sender.h" 11 #include "content/child/thread_safe_sender.h"
12 #include "content/common/service_worker/embedded_worker_messages.h" 12 #include "content/common/service_worker/embedded_worker_messages.h"
13 #include "content/renderer/render_thread_impl.h" 13 #include "content/renderer/render_thread_impl.h"
14 #include "content/renderer/service_worker/embedded_worker_dispatcher.h" 14 #include "content/renderer/service_worker/embedded_worker_dispatcher.h"
15 #include "content/renderer/service_worker/service_worker_script_context.h"
15 #include "ipc/ipc_message_macros.h" 16 #include "ipc/ipc_message_macros.h"
16 #include "third_party/WebKit/public/platform/WebString.h" 17 #include "third_party/WebKit/public/platform/WebString.h"
17 #include "webkit/child/worker_task_runner.h" 18 #include "webkit/child/worker_task_runner.h"
18 19
19 using webkit_glue::WorkerTaskRunner; 20 using webkit_glue::WorkerTaskRunner;
20 21
21 namespace content { 22 namespace content {
22 23
23 namespace { 24 namespace {
24 25
(...skipping 19 matching lines...) Expand all
44 } 45 }
45 46
46 EmbeddedWorkerContextClient::EmbeddedWorkerContextClient( 47 EmbeddedWorkerContextClient::EmbeddedWorkerContextClient(
47 int embedded_worker_id, 48 int embedded_worker_id,
48 int64 service_worker_version_id, 49 int64 service_worker_version_id,
49 const GURL& script_url) 50 const GURL& script_url)
50 : embedded_worker_id_(embedded_worker_id), 51 : embedded_worker_id_(embedded_worker_id),
51 service_worker_version_id_(service_worker_version_id), 52 service_worker_version_id_(service_worker_version_id),
52 script_url_(script_url), 53 script_url_(script_url),
53 sender_(ChildThread::current()->thread_safe_sender()), 54 sender_(ChildThread::current()->thread_safe_sender()),
54 main_thread_proxy_(base::MessageLoopProxy::current()), 55 main_thread_proxy_(base::MessageLoopProxy::current()) {
55 proxy_(NULL) {
56 g_worker_client_tls.Pointer()->Set(this); 56 g_worker_client_tls.Pointer()->Set(this);
57 } 57 }
58 58
59 EmbeddedWorkerContextClient::~EmbeddedWorkerContextClient() { 59 EmbeddedWorkerContextClient::~EmbeddedWorkerContextClient() {
60 DCHECK(g_worker_client_tls.Pointer()->Get() != NULL); 60 DCHECK(g_worker_client_tls.Pointer()->Get() != NULL);
61 g_worker_client_tls.Pointer()->Set(NULL); 61 g_worker_client_tls.Pointer()->Set(NULL);
62 } 62 }
63 63
64 bool EmbeddedWorkerContextClient::OnMessageReceived( 64 bool EmbeddedWorkerContextClient::OnMessageReceived(
65 const IPC::Message& msg) { 65 const IPC::Message& msg) {
66 bool handled = true; 66 bool handled = true;
67 IPC_BEGIN_MESSAGE_MAP(EmbeddedWorkerContextClient, msg) 67 IPC_BEGIN_MESSAGE_MAP(EmbeddedWorkerContextClient, msg)
68 IPC_MESSAGE_HANDLER(EmbeddedWorkerContextMsg_FetchEvent, OnFetchEvent) 68 IPC_MESSAGE_HANDLER(EmbeddedWorkerContextMsg_SendMessageToWorker,
69 OnSendMessageToWorker)
69 IPC_MESSAGE_UNHANDLED(handled = false) 70 IPC_MESSAGE_UNHANDLED(handled = false)
70 IPC_END_MESSAGE_MAP() 71 IPC_END_MESSAGE_MAP()
71 return handled; 72 return handled;
72 } 73 }
73 74
75 void EmbeddedWorkerContextClient::SendMessageToBrowser(
76 const IPC::Message& message) {
77 sender_->Send(new EmbeddedWorkerHostMsg_SendMessageToBrowser(
78 embedded_worker_id_, message));
79 }
80
74 void EmbeddedWorkerContextClient::workerContextFailedToStart() { 81 void EmbeddedWorkerContextClient::workerContextFailedToStart() {
75 DCHECK(main_thread_proxy_->RunsTasksOnCurrentThread()); 82 DCHECK(main_thread_proxy_->RunsTasksOnCurrentThread());
76 DCHECK(!proxy_); 83 DCHECK(!script_context_);
77 84
78 RenderThreadImpl::current()->embedded_worker_dispatcher()-> 85 RenderThreadImpl::current()->embedded_worker_dispatcher()->
79 WorkerContextDestroyed(embedded_worker_id_); 86 WorkerContextDestroyed(embedded_worker_id_);
80 } 87 }
81 88
82 void EmbeddedWorkerContextClient::workerContextStarted( 89 void EmbeddedWorkerContextClient::workerContextStarted(
83 blink::WebServiceWorkerContextProxy* proxy) { 90 blink::WebServiceWorkerContextProxy* proxy) {
84 DCHECK_NE(0, WorkerTaskRunner::Instance()->CurrentWorkerId()); 91 DCHECK_NE(0, WorkerTaskRunner::Instance()->CurrentWorkerId());
85 DCHECK(g_worker_client_tls.Pointer()->Get() == NULL); 92 DCHECK(g_worker_client_tls.Pointer()->Get() == NULL);
93 DCHECK(!script_context_);
86 g_worker_client_tls.Pointer()->Set(this); 94 g_worker_client_tls.Pointer()->Set(this);
87 proxy_ = proxy; 95 script_context_.reset(new ServiceWorkerScriptContext(this, proxy));
88 96
89 sender_->Send(new EmbeddedWorkerHostMsg_WorkerStarted( 97 sender_->Send(new EmbeddedWorkerHostMsg_WorkerStarted(
90 WorkerTaskRunner::Instance()->CurrentWorkerId(), 98 WorkerTaskRunner::Instance()->CurrentWorkerId(),
91 embedded_worker_id_)); 99 embedded_worker_id_));
92 } 100 }
93 101
94 void EmbeddedWorkerContextClient::workerContextDestroyed() { 102 void EmbeddedWorkerContextClient::workerContextDestroyed() {
95 // At this point OnWorkerRunLoopStopped is already called, so 103 // At this point OnWorkerRunLoopStopped is already called, so
96 // CurrentWorkerId() returns 0 (while we're still on the worker thread). 104 // CurrentWorkerId() returns 0 (while we're still on the worker thread).
97 proxy_ = NULL; 105 script_context_.reset();
98 main_thread_proxy_->PostTask( 106 main_thread_proxy_->PostTask(
99 FROM_HERE, 107 FROM_HERE,
100 base::Bind(&CallWorkerContextDestroyedOnMainThread, 108 base::Bind(&CallWorkerContextDestroyedOnMainThread,
101 embedded_worker_id_)); 109 embedded_worker_id_));
102 } 110 }
103 111
104 void EmbeddedWorkerContextClient::OnFetchEvent( 112 void EmbeddedWorkerContextClient::OnSendMessageToWorker(
105 int thread_id, 113 int thread_id,
106 int embedded_worker_id, 114 int embedded_worker_id,
107 const ServiceWorkerFetchRequest& request) { 115 const IPC::Message& message) {
108 // TODO(kinuko): Implement. 116 if (!script_context_)
109 // This is to call WebServiceWorkerContextProxy's dispatchFetchEvent method. 117 return;
110 NOTIMPLEMENTED(); 118 DCHECK_EQ(embedded_worker_id_, embedded_worker_id);
119 script_context_->OnMessageReceived(message);
111 } 120 }
112 121
113 } // namespace content 122 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698