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/strings/utf_string_conversions.h" | 9 #include "base/strings/utf_string_conversions.h" |
10 #include "content/child/scoped_child_process_reference.h" | 10 #include "content/child/scoped_child_process_reference.h" |
(...skipping 11 matching lines...) Expand all Loading... |
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::ExposeInterfacesToBrowser( | 29 void EmbeddedWorkerInstanceClientImpl::ExposeInterfacesToBrowser( |
30 service_manager::InterfaceRegistry* interface_registry) { | 30 service_manager::InterfaceRegistry* interface_registry) { |
31 DCHECK(renderer_request_.is_pending()); | 31 DCHECK(renderer_request_.is_pending()); |
32 interface_registry->Bind(std::move(renderer_request_)); | 32 interface_registry->Bind(std::move(renderer_request_), |
| 33 service_manager::Identity(), |
| 34 service_manager::InterfaceProviderSpec()); |
33 } | 35 } |
34 | 36 |
35 void EmbeddedWorkerInstanceClientImpl::StopWorkerCompleted() { | 37 void EmbeddedWorkerInstanceClientImpl::StopWorkerCompleted() { |
36 DCHECK(embedded_worker_id_); | 38 DCHECK(embedded_worker_id_); |
37 DCHECK(stop_callback_); | 39 DCHECK(stop_callback_); |
38 dispatcher_->UnregisterWorker(embedded_worker_id_.value()); | 40 dispatcher_->UnregisterWorker(embedded_worker_id_.value()); |
39 embedded_worker_id_.reset(); | 41 embedded_worker_id_.reset(); |
40 stop_callback_.Run(); | 42 stop_callback_.Run(); |
41 TRACE_EVENT0("ServiceWorker", | 43 TRACE_EVENT0("ServiceWorker", |
42 "EmbeddedWorkerInstanceClientImpl::StopWorkerCompleted"); | 44 "EmbeddedWorkerInstanceClientImpl::StopWorkerCompleted"); |
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
91 } | 93 } |
92 | 94 |
93 EmbeddedWorkerInstanceClientImpl::~EmbeddedWorkerInstanceClientImpl() {} | 95 EmbeddedWorkerInstanceClientImpl::~EmbeddedWorkerInstanceClientImpl() {} |
94 | 96 |
95 void EmbeddedWorkerInstanceClientImpl::OnError() { | 97 void EmbeddedWorkerInstanceClientImpl::OnError() { |
96 // Removes myself if it's owned by myself. | 98 // Removes myself if it's owned by myself. |
97 temporal_self_.reset(); | 99 temporal_self_.reset(); |
98 } | 100 } |
99 | 101 |
100 } // namespace content | 102 } // namespace content |
OLD | NEW |