OLD | NEW |
1 // Copyright (c) 2016 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2016 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_instance_client_impl.h
" | 5 #include "content/renderer/service_worker/embedded_worker_instance_client_impl.h
" |
6 | 6 |
7 #include <memory> | 7 #include <memory> |
8 | 8 |
9 #include "base/memory/ptr_util.h" | 9 #include "base/memory/ptr_util.h" |
10 #include "base/strings/utf_string_conversions.h" | 10 #include "base/strings/utf_string_conversions.h" |
(...skipping 10 matching lines...) Expand all Loading... |
21 // static | 21 // static |
22 void EmbeddedWorkerInstanceClientImpl::Create( | 22 void EmbeddedWorkerInstanceClientImpl::Create( |
23 EmbeddedWorkerDispatcher* dispatcher, | 23 EmbeddedWorkerDispatcher* dispatcher, |
24 mojo::InterfaceRequest<mojom::EmbeddedWorkerInstanceClient> request) { | 24 mojo::InterfaceRequest<mojom::EmbeddedWorkerInstanceClient> request) { |
25 // This won't be leaked because the lifetime will be managed internally. | 25 // This won't be leaked because the lifetime will be managed internally. |
26 new EmbeddedWorkerInstanceClientImpl(dispatcher, std::move(request)); | 26 new EmbeddedWorkerInstanceClientImpl(dispatcher, std::move(request)); |
27 } | 27 } |
28 | 28 |
29 void EmbeddedWorkerInstanceClientImpl::StopWorkerCompleted() { | 29 void EmbeddedWorkerInstanceClientImpl::StopWorkerCompleted() { |
30 DCHECK(embedded_worker_id_); | 30 DCHECK(embedded_worker_id_); |
31 DCHECK(stop_callback_); | |
32 TRACE_EVENT0("ServiceWorker", | 31 TRACE_EVENT0("ServiceWorker", |
33 "EmbeddedWorkerInstanceClientImpl::StopWorkerCompleted"); | 32 "EmbeddedWorkerInstanceClientImpl::StopWorkerCompleted"); |
34 // TODO(falken): The signals to the browser should be in the order: | |
35 // (1) WorkerStopped (via stop_callback_) | |
36 // (2) ProviderDestroyed (via UnregisterWorker destroying | |
37 // WebEmbeddedWorkerImpl) | |
38 // But this ordering is currently not guaranteed since the Mojo pipes are | |
39 // different. https://crbug.com/676526 | |
40 stop_callback_.Run(); | |
41 stop_callback_.Reset(); | |
42 dispatcher_->UnregisterWorker(embedded_worker_id_.value()); | 33 dispatcher_->UnregisterWorker(embedded_worker_id_.value()); |
43 embedded_worker_id_.reset(); | 34 embedded_worker_id_.reset(); |
44 wrapper_ = nullptr; | 35 wrapper_ = nullptr; |
45 } | 36 } |
46 | 37 |
47 void EmbeddedWorkerInstanceClientImpl::StartWorker( | 38 void EmbeddedWorkerInstanceClientImpl::StartWorker( |
48 const EmbeddedWorkerStartParams& params, | 39 const EmbeddedWorkerStartParams& params, |
49 mojom::ServiceWorkerEventDispatcherRequest dispatcher_request) { | 40 mojom::ServiceWorkerEventDispatcherRequest dispatcher_request, |
| 41 mojom::EmbeddedWorkerInstanceHostAssociatedPtrInfo instance_host) { |
50 DCHECK(ChildThreadImpl::current()); | 42 DCHECK(ChildThreadImpl::current()); |
51 DCHECK(!wrapper_); | 43 DCHECK(!wrapper_); |
52 DCHECK(!embedded_worker_id_); | 44 DCHECK(!embedded_worker_id_); |
53 TRACE_EVENT0("ServiceWorker", | 45 TRACE_EVENT0("ServiceWorker", |
54 "EmbeddedWorkerInstanceClientImpl::StartWorker"); | 46 "EmbeddedWorkerInstanceClientImpl::StartWorker"); |
55 embedded_worker_id_ = params.embedded_worker_id; | 47 embedded_worker_id_ = params.embedded_worker_id; |
56 | 48 |
57 std::unique_ptr<EmbeddedWorkerDispatcher::WorkerWrapper> wrapper = | 49 std::unique_ptr<EmbeddedWorkerDispatcher::WorkerWrapper> wrapper = |
58 dispatcher_->StartWorkerContext( | 50 dispatcher_->StartWorkerContext( |
59 params, | 51 params, |
60 base::MakeUnique<ServiceWorkerContextClient>( | 52 base::MakeUnique<ServiceWorkerContextClient>( |
61 params.embedded_worker_id, params.service_worker_version_id, | 53 params.embedded_worker_id, params.service_worker_version_id, |
62 params.scope, params.script_url, | 54 params.scope, params.script_url, std::move(dispatcher_request), |
63 std::move(dispatcher_request), std::move(temporal_self_))); | 55 std::move(instance_host), std::move(temporal_self_))); |
64 wrapper_ = wrapper.get(); | 56 wrapper_ = wrapper.get(); |
65 dispatcher_->RegisterWorker(params.embedded_worker_id, std::move(wrapper)); | 57 dispatcher_->RegisterWorker(params.embedded_worker_id, std::move(wrapper)); |
66 } | 58 } |
67 | 59 |
68 void EmbeddedWorkerInstanceClientImpl::StopWorker( | 60 void EmbeddedWorkerInstanceClientImpl::StopWorker() { |
69 const StopWorkerCallback& callback) { | |
70 // StopWorker must be called after StartWorker is called. | 61 // StopWorker must be called after StartWorker is called. |
71 DCHECK(ChildThreadImpl::current()); | 62 DCHECK(ChildThreadImpl::current()); |
72 DCHECK(wrapper_); | 63 DCHECK(wrapper_); |
73 DCHECK(embedded_worker_id_); | 64 DCHECK(embedded_worker_id_); |
74 DCHECK(!stop_callback_); | |
75 | 65 |
76 TRACE_EVENT0("ServiceWorker", "EmbeddedWorkerInstanceClientImpl::StopWorker"); | 66 TRACE_EVENT0("ServiceWorker", "EmbeddedWorkerInstanceClientImpl::StopWorker"); |
77 stop_callback_ = callback; | |
78 dispatcher_->RecordStopWorkerTimer(embedded_worker_id_.value()); | 67 dispatcher_->RecordStopWorkerTimer(embedded_worker_id_.value()); |
79 wrapper_->worker()->terminateWorkerContext(); | 68 wrapper_->worker()->terminateWorkerContext(); |
80 } | 69 } |
81 | 70 |
82 void EmbeddedWorkerInstanceClientImpl::ResumeAfterDownload() { | 71 void EmbeddedWorkerInstanceClientImpl::ResumeAfterDownload() { |
83 DCHECK(wrapper_); | 72 DCHECK(wrapper_); |
84 DCHECK(wrapper_->worker()); | 73 DCHECK(wrapper_->worker()); |
85 wrapper_->worker()->resumeAfterDownload(); | 74 wrapper_->worker()->resumeAfterDownload(); |
86 } | 75 } |
87 | 76 |
(...skipping 18 matching lines...) Expand all Loading... |
106 } | 95 } |
107 | 96 |
108 EmbeddedWorkerInstanceClientImpl::~EmbeddedWorkerInstanceClientImpl() {} | 97 EmbeddedWorkerInstanceClientImpl::~EmbeddedWorkerInstanceClientImpl() {} |
109 | 98 |
110 void EmbeddedWorkerInstanceClientImpl::OnError() { | 99 void EmbeddedWorkerInstanceClientImpl::OnError() { |
111 // Removes myself if it's owned by myself. | 100 // Removes myself if it's owned by myself. |
112 temporal_self_.reset(); | 101 temporal_self_.reset(); |
113 } | 102 } |
114 | 103 |
115 } // namespace content | 104 } // namespace content |
OLD | NEW |