| 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 28 matching lines...) Expand all Loading... |
| 39 // different. https://crbug.com/676526 | 39 // different. https://crbug.com/676526 |
| 40 stop_callback_.Run(); | 40 stop_callback_.Run(); |
| 41 stop_callback_.Reset(); | 41 stop_callback_.Reset(); |
| 42 dispatcher_->UnregisterWorker(embedded_worker_id_.value()); | 42 dispatcher_->UnregisterWorker(embedded_worker_id_.value()); |
| 43 embedded_worker_id_.reset(); | 43 embedded_worker_id_.reset(); |
| 44 wrapper_ = nullptr; | 44 wrapper_ = nullptr; |
| 45 } | 45 } |
| 46 | 46 |
| 47 void EmbeddedWorkerInstanceClientImpl::StartWorker( | 47 void EmbeddedWorkerInstanceClientImpl::StartWorker( |
| 48 const EmbeddedWorkerStartParams& params, | 48 const EmbeddedWorkerStartParams& params, |
| 49 mojom::ServiceWorkerEventDispatcherRequest dispatcher_request) { | 49 mojom::ServiceWorkerEventDispatcherRequest dispatcher_request, |
| 50 mojom::EmbeddedWorkerInstanceHostAssociatedPtrInfo instance_host) { |
| 50 DCHECK(ChildThreadImpl::current()); | 51 DCHECK(ChildThreadImpl::current()); |
| 51 DCHECK(!wrapper_); | 52 DCHECK(!wrapper_); |
| 52 DCHECK(!embedded_worker_id_); | 53 DCHECK(!embedded_worker_id_); |
| 53 TRACE_EVENT0("ServiceWorker", | 54 TRACE_EVENT0("ServiceWorker", |
| 54 "EmbeddedWorkerInstanceClientImpl::StartWorker"); | 55 "EmbeddedWorkerInstanceClientImpl::StartWorker"); |
| 55 embedded_worker_id_ = params.embedded_worker_id; | 56 embedded_worker_id_ = params.embedded_worker_id; |
| 56 | 57 |
| 57 std::unique_ptr<EmbeddedWorkerDispatcher::WorkerWrapper> wrapper = | 58 std::unique_ptr<EmbeddedWorkerDispatcher::WorkerWrapper> wrapper = |
| 58 dispatcher_->StartWorkerContext( | 59 dispatcher_->StartWorkerContext( |
| 59 params, | 60 params, |
| 60 base::MakeUnique<ServiceWorkerContextClient>( | 61 base::MakeUnique<ServiceWorkerContextClient>( |
| 61 params.embedded_worker_id, params.service_worker_version_id, | 62 params.embedded_worker_id, params.service_worker_version_id, |
| 62 params.scope, params.script_url, | 63 params.scope, params.script_url, std::move(dispatcher_request), |
| 63 std::move(dispatcher_request), std::move(temporal_self_))); | 64 std::move(instance_host), std::move(temporal_self_))); |
| 64 wrapper_ = wrapper.get(); | 65 wrapper_ = wrapper.get(); |
| 65 dispatcher_->RegisterWorker(params.embedded_worker_id, std::move(wrapper)); | 66 dispatcher_->RegisterWorker(params.embedded_worker_id, std::move(wrapper)); |
| 66 } | 67 } |
| 67 | 68 |
| 68 void EmbeddedWorkerInstanceClientImpl::StopWorker( | 69 void EmbeddedWorkerInstanceClientImpl::StopWorker( |
| 69 const StopWorkerCallback& callback) { | 70 const StopWorkerCallback& callback) { |
| 70 // StopWorker must be called after StartWorker is called. | 71 // StopWorker must be called after StartWorker is called. |
| 71 DCHECK(ChildThreadImpl::current()); | 72 DCHECK(ChildThreadImpl::current()); |
| 72 DCHECK(wrapper_); | 73 DCHECK(wrapper_); |
| 73 DCHECK(embedded_worker_id_); | 74 DCHECK(embedded_worker_id_); |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 106 } | 107 } |
| 107 | 108 |
| 108 EmbeddedWorkerInstanceClientImpl::~EmbeddedWorkerInstanceClientImpl() {} | 109 EmbeddedWorkerInstanceClientImpl::~EmbeddedWorkerInstanceClientImpl() {} |
| 109 | 110 |
| 110 void EmbeddedWorkerInstanceClientImpl::OnError() { | 111 void EmbeddedWorkerInstanceClientImpl::OnError() { |
| 111 // Removes myself if it's owned by myself. | 112 // Removes myself if it's owned by myself. |
| 112 temporal_self_.reset(); | 113 temporal_self_.reset(); |
| 113 } | 114 } |
| 114 | 115 |
| 115 } // namespace content | 116 } // namespace content |
| OLD | NEW |