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_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" |
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
46 EmbeddedWorkerContextClient::EmbeddedWorkerContextClient( | 46 EmbeddedWorkerContextClient::EmbeddedWorkerContextClient( |
47 int embedded_worker_id, | 47 int embedded_worker_id, |
48 int64 service_worker_version_id, | 48 int64 service_worker_version_id, |
49 const GURL& script_url) | 49 const GURL& script_url) |
50 : embedded_worker_id_(embedded_worker_id), | 50 : embedded_worker_id_(embedded_worker_id), |
51 service_worker_version_id_(service_worker_version_id), | 51 service_worker_version_id_(service_worker_version_id), |
52 script_url_(script_url), | 52 script_url_(script_url), |
53 sender_(ChildThread::current()->thread_safe_sender()), | 53 sender_(ChildThread::current()->thread_safe_sender()), |
54 main_thread_proxy_(base::MessageLoopProxy::current()), | 54 main_thread_proxy_(base::MessageLoopProxy::current()), |
55 proxy_(NULL) { | 55 proxy_(NULL) { |
| 56 g_worker_client_tls.Pointer()->Set(this); |
56 } | 57 } |
57 | 58 |
58 EmbeddedWorkerContextClient::~EmbeddedWorkerContextClient() { | 59 EmbeddedWorkerContextClient::~EmbeddedWorkerContextClient() { |
59 DCHECK(g_worker_client_tls.Pointer()->Get() != NULL); | 60 DCHECK(g_worker_client_tls.Pointer()->Get() != NULL); |
60 g_worker_client_tls.Pointer()->Set(NULL); | 61 g_worker_client_tls.Pointer()->Set(NULL); |
61 } | 62 } |
62 | 63 |
63 bool EmbeddedWorkerContextClient::OnMessageReceived( | 64 bool EmbeddedWorkerContextClient::OnMessageReceived( |
64 const IPC::Message& msg) { | 65 const IPC::Message& msg) { |
65 bool handled = true; | 66 bool handled = true; |
(...skipping 18 matching lines...) Expand all Loading... |
84 DCHECK(g_worker_client_tls.Pointer()->Get() == NULL); | 85 DCHECK(g_worker_client_tls.Pointer()->Get() == NULL); |
85 g_worker_client_tls.Pointer()->Set(this); | 86 g_worker_client_tls.Pointer()->Set(this); |
86 proxy_ = proxy; | 87 proxy_ = proxy; |
87 | 88 |
88 sender_->Send(new EmbeddedWorkerHostMsg_WorkerStarted( | 89 sender_->Send(new EmbeddedWorkerHostMsg_WorkerStarted( |
89 WorkerTaskRunner::Instance()->CurrentWorkerId(), | 90 WorkerTaskRunner::Instance()->CurrentWorkerId(), |
90 embedded_worker_id_)); | 91 embedded_worker_id_)); |
91 } | 92 } |
92 | 93 |
93 void EmbeddedWorkerContextClient::workerContextDestroyed() { | 94 void EmbeddedWorkerContextClient::workerContextDestroyed() { |
94 DCHECK_NE(0, WorkerTaskRunner::Instance()->CurrentWorkerId()); | 95 // At this point OnWorkerRunLoopStopped is already called, so |
| 96 // CurrentWorkerId() returns 0 (while we're still on the worker thread). |
95 proxy_ = NULL; | 97 proxy_ = NULL; |
96 main_thread_proxy_->PostTask( | 98 main_thread_proxy_->PostTask( |
97 FROM_HERE, | 99 FROM_HERE, |
98 base::Bind(&CallWorkerContextDestroyedOnMainThread, | 100 base::Bind(&CallWorkerContextDestroyedOnMainThread, |
99 embedded_worker_id_)); | 101 embedded_worker_id_)); |
100 } | 102 } |
101 | 103 |
102 void EmbeddedWorkerContextClient::OnFetchEvent( | 104 void EmbeddedWorkerContextClient::OnFetchEvent( |
103 int thread_id, | 105 int thread_id, |
104 int embedded_worker_id, | 106 int embedded_worker_id, |
105 const ServiceWorkerFetchRequest& request) { | 107 const ServiceWorkerFetchRequest& request) { |
106 // TODO(kinuko): Implement. | 108 // TODO(kinuko): Implement. |
107 // This is to call WebServiceWorkerContextProxy's dispatchFetchEvent method. | 109 // This is to call WebServiceWorkerContextProxy's dispatchFetchEvent method. |
108 NOTIMPLEMENTED(); | 110 NOTIMPLEMENTED(); |
109 } | 111 } |
110 | 112 |
111 } // namespace content | 113 } // namespace content |
OLD | NEW |