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/service_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_messages.h" |
12 #include "content/renderer/render_thread_impl.h" | 13 #include "content/renderer/render_thread_impl.h" |
13 #include "content/renderer/service_worker/embedded_worker_dispatcher.h" | 14 #include "content/renderer/service_worker/embedded_worker_dispatcher.h" |
14 #include "ipc/ipc_message_macros.h" | 15 #include "ipc/ipc_message_macros.h" |
15 #include "third_party/WebKit/public/platform/WebString.h" | 16 #include "third_party/WebKit/public/platform/WebString.h" |
16 #include "webkit/child/worker_task_runner.h" | 17 #include "webkit/child/worker_task_runner.h" |
17 | 18 |
18 using webkit_glue::WorkerTaskRunner; | 19 using webkit_glue::WorkerTaskRunner; |
19 | 20 |
20 namespace content { | 21 namespace content { |
21 | 22 |
22 namespace { | 23 namespace { |
23 | 24 |
24 // For now client must be a per-thread instance. | 25 // For now client must be a per-thread instance. |
25 // TODO(kinuko): This needs to be refactored when we start using thread pool | 26 // TODO(kinuko): This needs to be refactored when we start using thread pool |
26 // or having multiple clients per one thread. | 27 // or having multiple clients per one thread. |
27 base::LazyInstance<base::ThreadLocalPointer<ServiceWorkerContextClient> >:: | 28 base::LazyInstance<base::ThreadLocalPointer<EmbeddedWorkerContextClient> >:: |
28 Leaky g_worker_client_tls = LAZY_INSTANCE_INITIALIZER; | 29 Leaky g_worker_client_tls = LAZY_INSTANCE_INITIALIZER; |
29 | 30 |
30 void CallWorkerContextDestroyedOnMainThread(int embedded_worker_id) { | 31 void CallWorkerContextDestroyedOnMainThread(int embedded_worker_id) { |
31 if (!RenderThreadImpl::current() || | 32 if (!RenderThreadImpl::current() || |
32 !RenderThreadImpl::current()->embedded_worker_dispatcher()) | 33 !RenderThreadImpl::current()->embedded_worker_dispatcher()) |
33 return; | 34 return; |
34 RenderThreadImpl::current()->embedded_worker_dispatcher()-> | 35 RenderThreadImpl::current()->embedded_worker_dispatcher()-> |
35 WorkerContextDestroyed(embedded_worker_id); | 36 WorkerContextDestroyed(embedded_worker_id); |
36 } | 37 } |
37 | 38 |
38 } // namespace | 39 } // namespace |
39 | 40 |
40 ServiceWorkerContextClient* | 41 EmbeddedWorkerContextClient* |
41 ServiceWorkerContextClient::ThreadSpecificInstance() { | 42 EmbeddedWorkerContextClient::ThreadSpecificInstance() { |
42 return g_worker_client_tls.Pointer()->Get(); | 43 return g_worker_client_tls.Pointer()->Get(); |
43 } | 44 } |
44 | 45 |
45 ServiceWorkerContextClient::ServiceWorkerContextClient( | 46 EmbeddedWorkerContextClient::EmbeddedWorkerContextClient( |
46 int embedded_worker_id, | 47 int embedded_worker_id, |
47 int64 service_worker_version_id, | 48 int64 service_worker_version_id, |
48 const GURL& script_url) | 49 const GURL& script_url) |
49 : embedded_worker_id_(embedded_worker_id), | 50 : embedded_worker_id_(embedded_worker_id), |
50 service_worker_version_id_(service_worker_version_id), | 51 service_worker_version_id_(service_worker_version_id), |
51 script_url_(script_url), | 52 script_url_(script_url), |
52 sender_(ChildThread::current()->thread_safe_sender()), | 53 sender_(ChildThread::current()->thread_safe_sender()), |
53 main_thread_proxy_(base::MessageLoopProxy::current()), | 54 main_thread_proxy_(base::MessageLoopProxy::current()), |
54 proxy_(NULL) { | 55 proxy_(NULL) { |
55 } | 56 } |
56 | 57 |
57 ServiceWorkerContextClient::~ServiceWorkerContextClient() { | 58 EmbeddedWorkerContextClient::~EmbeddedWorkerContextClient() { |
58 DCHECK(g_worker_client_tls.Pointer()->Get() != NULL); | 59 DCHECK(g_worker_client_tls.Pointer()->Get() != NULL); |
59 g_worker_client_tls.Pointer()->Set(NULL); | 60 g_worker_client_tls.Pointer()->Set(NULL); |
60 } | 61 } |
61 | 62 |
62 bool ServiceWorkerContextClient::OnMessageReceived( | 63 bool EmbeddedWorkerContextClient::OnMessageReceived( |
63 const IPC::Message& msg) { | 64 const IPC::Message& msg) { |
64 NOTIMPLEMENTED(); | 65 bool handled = true; |
65 return false; | 66 IPC_BEGIN_MESSAGE_MAP(EmbeddedWorkerContextClient, msg) |
| 67 IPC_MESSAGE_HANDLER(EmbeddedWorkerContextMsg_FetchEvent, OnFetchEvent) |
| 68 IPC_MESSAGE_UNHANDLED(handled = false) |
| 69 IPC_END_MESSAGE_MAP() |
| 70 return handled; |
66 } | 71 } |
67 | 72 |
68 void ServiceWorkerContextClient::workerContextFailedToStart() | 73 void EmbeddedWorkerContextClient::workerContextFailedToStart() { |
69 { | |
70 DCHECK(main_thread_proxy_->RunsTasksOnCurrentThread()); | 74 DCHECK(main_thread_proxy_->RunsTasksOnCurrentThread()); |
71 DCHECK(!proxy_); | 75 DCHECK(!proxy_); |
72 | 76 |
73 RenderThreadImpl::current()->embedded_worker_dispatcher()-> | 77 RenderThreadImpl::current()->embedded_worker_dispatcher()-> |
74 WorkerContextDestroyed(embedded_worker_id_); | 78 WorkerContextDestroyed(embedded_worker_id_); |
75 } | 79 } |
76 | 80 |
77 void ServiceWorkerContextClient::workerContextStarted( | 81 void EmbeddedWorkerContextClient::workerContextStarted( |
78 blink::WebServiceWorkerContextProxy* proxy) { | 82 blink::WebServiceWorkerContextProxy* proxy) { |
79 DCHECK_NE(0, WorkerTaskRunner::Instance()->CurrentWorkerId()); | 83 DCHECK_NE(0, WorkerTaskRunner::Instance()->CurrentWorkerId()); |
80 DCHECK(g_worker_client_tls.Pointer()->Get() == NULL); | 84 DCHECK(g_worker_client_tls.Pointer()->Get() == NULL); |
81 g_worker_client_tls.Pointer()->Set(this); | 85 g_worker_client_tls.Pointer()->Set(this); |
82 proxy_ = proxy; | 86 proxy_ = proxy; |
83 | 87 |
84 // TODO(kinuko): Send WorkerStarted message to the browser with the | 88 sender_->Send(new EmbeddedWorkerHostMsg_WorkerStarted( |
85 // current thread ID so that the browser can start sending embedded worker | 89 WorkerTaskRunner::Instance()->CurrentWorkerId(), |
86 // messages directly to this client. | 90 embedded_worker_id_)); |
87 } | 91 } |
88 | 92 |
89 void ServiceWorkerContextClient::workerContextDestroyed() { | 93 void EmbeddedWorkerContextClient::workerContextDestroyed() { |
90 DCHECK_NE(0, WorkerTaskRunner::Instance()->CurrentWorkerId()); | 94 DCHECK_NE(0, WorkerTaskRunner::Instance()->CurrentWorkerId()); |
91 proxy_ = NULL; | 95 proxy_ = NULL; |
92 main_thread_proxy_->PostTask( | 96 main_thread_proxy_->PostTask( |
93 FROM_HERE, | 97 FROM_HERE, |
94 base::Bind(&CallWorkerContextDestroyedOnMainThread, | 98 base::Bind(&CallWorkerContextDestroyedOnMainThread, |
95 embedded_worker_id_)); | 99 embedded_worker_id_)); |
96 } | 100 } |
97 | 101 |
| 102 void EmbeddedWorkerContextClient::OnFetchEvent( |
| 103 int thread_id, |
| 104 int embedded_worker_id, |
| 105 const ServiceWorkerFetchRequest& request) { |
| 106 // TODO(kinuko): Implement. |
| 107 // This is to call WebServiceWorkerContextProxy's dispatchFetchEvent method. |
| 108 NOTIMPLEMENTED(); |
| 109 } |
| 110 |
98 } // namespace content | 111 } // namespace content |
OLD | NEW |