OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/shared_worker/embedded_shared_worker_stub.h" | 5 #include "content/renderer/shared_worker/embedded_shared_worker_stub.h" |
6 | 6 |
7 #include <stdint.h> | 7 #include <stdint.h> |
8 #include <utility> | 8 #include <utility> |
9 | 9 |
10 #include "base/thread_task_runner_handle.h" | 10 #include "base/thread_task_runner_handle.h" |
(...skipping 65 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
76 // Called on the main thread only and blink owns it. | 76 // Called on the main thread only and blink owns it. |
77 class WebServiceWorkerNetworkProviderImpl | 77 class WebServiceWorkerNetworkProviderImpl |
78 : public blink::WebServiceWorkerNetworkProvider { | 78 : public blink::WebServiceWorkerNetworkProvider { |
79 public: | 79 public: |
80 // Blink calls this method for each request starting with the main script, | 80 // Blink calls this method for each request starting with the main script, |
81 // we tag them with the provider id. | 81 // we tag them with the provider id. |
82 void willSendRequest(blink::WebDataSource* data_source, | 82 void willSendRequest(blink::WebDataSource* data_source, |
83 blink::WebURLRequest& request) override { | 83 blink::WebURLRequest& request) override { |
84 ServiceWorkerNetworkProvider* provider = | 84 ServiceWorkerNetworkProvider* provider = |
85 GetNetworkProviderFromDataSource(data_source); | 85 GetNetworkProviderFromDataSource(data_source); |
86 scoped_ptr<RequestExtraData> extra_data(new RequestExtraData); | 86 std::unique_ptr<RequestExtraData> extra_data(new RequestExtraData); |
87 extra_data->set_service_worker_provider_id(provider->provider_id()); | 87 extra_data->set_service_worker_provider_id(provider->provider_id()); |
88 request.setExtraData(extra_data.release()); | 88 request.setExtraData(extra_data.release()); |
89 // Explicitly set the SkipServiceWorker flag for subresources here if the | 89 // Explicitly set the SkipServiceWorker flag for subresources here if the |
90 // renderer process hasn't received SetControllerServiceWorker message. | 90 // renderer process hasn't received SetControllerServiceWorker message. |
91 if (request.getRequestContext() != | 91 if (request.getRequestContext() != |
92 blink::WebURLRequest::RequestContextSharedWorker && | 92 blink::WebURLRequest::RequestContextSharedWorker && |
93 !provider->IsControlledByServiceWorker()) { | 93 !provider->IsControlledByServiceWorker()) { |
94 request.setSkipServiceWorker(true); | 94 request.setSkipServiceWorker(true); |
95 } | 95 } |
96 } | 96 } |
(...skipping 135 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
232 origin.isUnique(), | 232 origin.isUnique(), |
233 route_id_, | 233 route_id_, |
234 ChildThreadImpl::current()->thread_safe_sender()); | 234 ChildThreadImpl::current()->thread_safe_sender()); |
235 } | 235 } |
236 | 236 |
237 blink::WebServiceWorkerNetworkProvider* | 237 blink::WebServiceWorkerNetworkProvider* |
238 EmbeddedSharedWorkerStub::createServiceWorkerNetworkProvider( | 238 EmbeddedSharedWorkerStub::createServiceWorkerNetworkProvider( |
239 blink::WebDataSource* data_source) { | 239 blink::WebDataSource* data_source) { |
240 // Create a content::ServiceWorkerNetworkProvider for this data source so | 240 // Create a content::ServiceWorkerNetworkProvider for this data source so |
241 // we can observe its requests. | 241 // we can observe its requests. |
242 scoped_ptr<ServiceWorkerNetworkProvider> provider( | 242 std::unique_ptr<ServiceWorkerNetworkProvider> provider( |
243 new ServiceWorkerNetworkProvider( | 243 new ServiceWorkerNetworkProvider( |
244 route_id_, SERVICE_WORKER_PROVIDER_FOR_SHARED_WORKER)); | 244 route_id_, SERVICE_WORKER_PROVIDER_FOR_SHARED_WORKER)); |
245 | 245 |
246 // The provider is kept around for the lifetime of the DataSource | 246 // The provider is kept around for the lifetime of the DataSource |
247 // and ownership is transferred to the DataSource. | 247 // and ownership is transferred to the DataSource. |
248 DataSourceExtraData* extra_data = new DataSourceExtraData(); | 248 DataSourceExtraData* extra_data = new DataSourceExtraData(); |
249 data_source->setExtraData(extra_data); | 249 data_source->setExtraData(extra_data); |
250 ServiceWorkerNetworkProvider::AttachToDocumentState(extra_data, | 250 ServiceWorkerNetworkProvider::AttachToDocumentState(extra_data, |
251 std::move(provider)); | 251 std::move(provider)); |
252 | 252 |
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
298 } | 298 } |
299 } | 299 } |
300 | 300 |
301 void EmbeddedSharedWorkerStub::OnTerminateWorkerContext() { | 301 void EmbeddedSharedWorkerStub::OnTerminateWorkerContext() { |
302 // After this we wouldn't get any IPC for this stub. | 302 // After this we wouldn't get any IPC for this stub. |
303 running_ = false; | 303 running_ = false; |
304 impl_->terminateWorkerContext(); | 304 impl_->terminateWorkerContext(); |
305 } | 305 } |
306 | 306 |
307 } // namespace content | 307 } // namespace content |
OLD | NEW |