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 "chrome/browser/predictors/resource_prefetcher.h" | 5 #include "chrome/browser/predictors/resource_prefetcher.h" |
6 | 6 |
7 #include <iterator> | 7 #include <iterator> |
8 | 8 |
9 #include "base/profiler/scoped_tracker.h" | 9 #include "base/profiler/scoped_tracker.h" |
10 #include "base/stl_util.h" | 10 #include "base/stl_util.h" |
11 #include "content/public/browser/browser_thread.h" | 11 #include "content/public/browser/browser_thread.h" |
12 #include "net/base/io_buffer.h" | 12 #include "net/base/io_buffer.h" |
| 13 #include "net/base/load_flags.h" |
13 #include "net/base/request_priority.h" | 14 #include "net/base/request_priority.h" |
14 #include "net/url_request/url_request_context.h" | 15 #include "net/url_request/url_request_context.h" |
15 | 16 |
16 namespace { | 17 namespace { |
17 | 18 |
18 // The size of the buffer used to read the resource. | 19 // The size of the buffer used to read the resource. |
19 static const size_t kResourceBufferSizeBytes = 50000; | 20 static const size_t kResourceBufferSizeBytes = 50000; |
20 | 21 |
21 } // namespace | 22 } // namespace |
22 | 23 |
(...skipping 104 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
127 net::URLRequest* url_request = | 128 net::URLRequest* url_request = |
128 delegate_->GetURLRequestContext()->CreateRequest( | 129 delegate_->GetURLRequestContext()->CreateRequest( |
129 request->resource_url, net::LOW, this, NULL).release(); | 130 request->resource_url, net::LOW, this, NULL).release(); |
130 | 131 |
131 inflight_requests_[url_request] = request; | 132 inflight_requests_[url_request] = request; |
132 host_inflight_counts_[url_request->original_url().host()] += 1; | 133 host_inflight_counts_[url_request->original_url().host()] += 1; |
133 | 134 |
134 url_request->set_method("GET"); | 135 url_request->set_method("GET"); |
135 url_request->set_first_party_for_cookies(navigation_id_.main_frame_url); | 136 url_request->set_first_party_for_cookies(navigation_id_.main_frame_url); |
136 url_request->SetReferrer(navigation_id_.main_frame_url.spec()); | 137 url_request->SetReferrer(navigation_id_.main_frame_url.spec()); |
| 138 url_request->SetLoadFlags(url_request->load_flags() | net::LOAD_PREFETCH); |
137 StartURLRequest(url_request); | 139 StartURLRequest(url_request); |
138 } | 140 } |
139 | 141 |
140 void ResourcePrefetcher::StartURLRequest(net::URLRequest* request) { | 142 void ResourcePrefetcher::StartURLRequest(net::URLRequest* request) { |
141 request->Start(); | 143 request->Start(); |
142 } | 144 } |
143 | 145 |
144 void ResourcePrefetcher::FinishRequest(net::URLRequest* request, | 146 void ResourcePrefetcher::FinishRequest(net::URLRequest* request, |
145 Request::PrefetchStatus status) { | 147 Request::PrefetchStatus status) { |
146 std::map<net::URLRequest*, Request*>::iterator request_it = | 148 std::map<net::URLRequest*, Request*>::iterator request_it = |
(...skipping 95 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
242 if (request->status().error()) { | 244 if (request->status().error()) { |
243 FinishRequest(request, Request::PREFETCH_STATUS_FAILED); | 245 FinishRequest(request, Request::PREFETCH_STATUS_FAILED); |
244 return; | 246 return; |
245 } | 247 } |
246 | 248 |
247 if (ShouldContinueReadingRequest(request, bytes_read)) | 249 if (ShouldContinueReadingRequest(request, bytes_read)) |
248 ReadFullResponse(request); | 250 ReadFullResponse(request); |
249 } | 251 } |
250 | 252 |
251 } // namespace predictors | 253 } // namespace predictors |
OLD | NEW |