OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 <iterator> | 5 #include <iterator> |
6 | 6 |
7 #include "chrome/browser/predictors/resource_prefetcher.h" | 7 #include "chrome/browser/predictors/resource_prefetcher.h" |
8 | 8 |
9 #include "base/stl_util.h" | 9 #include "base/stl_util.h" |
10 #include "content/public/browser/browser_thread.h" | 10 #include "content/public/browser/browser_thread.h" |
11 #include "net/base/io_buffer.h" | 11 #include "net/base/io_buffer.h" |
| 12 #include "net/base/request_priority.h" |
| 13 #include "net/url_request/url_request_context.h" |
12 | 14 |
13 namespace { | 15 namespace { |
14 | 16 |
15 // The size of the buffer used to read the resource. | 17 // The size of the buffer used to read the resource. |
16 static const size_t kResourceBufferSizeBytes = 50000; | 18 static const size_t kResourceBufferSizeBytes = 50000; |
17 | 19 |
18 } // namespace | 20 } // namespace |
19 | 21 |
20 namespace predictors { | 22 namespace predictors { |
21 | 23 |
(...skipping 92 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
114 CHECK(request_queue_.empty() || state_ == STOPPED); | 116 CHECK(request_queue_.empty() || state_ == STOPPED); |
115 | 117 |
116 state_ = FINISHED; | 118 state_ = FINISHED; |
117 delegate_->ResourcePrefetcherFinished(this, request_vector_.release()); | 119 delegate_->ResourcePrefetcherFinished(this, request_vector_.release()); |
118 } | 120 } |
119 } | 121 } |
120 | 122 |
121 void ResourcePrefetcher::SendRequest(Request* request) { | 123 void ResourcePrefetcher::SendRequest(Request* request) { |
122 request->prefetch_status = Request::PREFETCH_STATUS_STARTED; | 124 request->prefetch_status = Request::PREFETCH_STATUS_STARTED; |
123 | 125 |
124 net::URLRequest* url_request = | 126 net::URLRequest* url_request = new net::URLRequest( |
125 new net::URLRequest(request->resource_url, | 127 request->resource_url, |
126 this, | 128 net::LOW, |
127 delegate_->GetURLRequestContext()); | 129 this, |
| 130 delegate_->GetURLRequestContext(), |
| 131 delegate_->GetURLRequestContext()->network_delegate()); |
128 inflight_requests_[url_request] = request; | 132 inflight_requests_[url_request] = request; |
129 host_inflight_counts_[url_request->original_url().host()] += 1; | 133 host_inflight_counts_[url_request->original_url().host()] += 1; |
130 | 134 |
131 url_request->set_method("GET"); | 135 url_request->set_method("GET"); |
132 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); |
133 url_request->SetReferrer(navigation_id_.main_frame_url.spec()); | 137 url_request->SetReferrer(navigation_id_.main_frame_url.spec()); |
134 url_request->SetPriority(net::LOW); | |
135 StartURLRequest(url_request); | 138 StartURLRequest(url_request); |
136 } | 139 } |
137 | 140 |
138 void ResourcePrefetcher::StartURLRequest(net::URLRequest* request) { | 141 void ResourcePrefetcher::StartURLRequest(net::URLRequest* request) { |
139 request->Start(); | 142 request->Start(); |
140 } | 143 } |
141 | 144 |
142 void ResourcePrefetcher::FinishRequest(net::URLRequest* request, | 145 void ResourcePrefetcher::FinishRequest(net::URLRequest* request, |
143 Request::PrefetchStatus status) { | 146 Request::PrefetchStatus status) { |
144 std::map<net::URLRequest*, Request*>::iterator request_it = | 147 std::map<net::URLRequest*, Request*>::iterator request_it = |
(...skipping 84 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
229 if (request->status().error()) { | 232 if (request->status().error()) { |
230 FinishRequest(request, Request::PREFETCH_STATUS_FAILED); | 233 FinishRequest(request, Request::PREFETCH_STATUS_FAILED); |
231 return; | 234 return; |
232 } | 235 } |
233 | 236 |
234 if (ShouldContinueReadingRequest(request, bytes_read)) | 237 if (ShouldContinueReadingRequest(request, bytes_read)) |
235 ReadFullResponse(request); | 238 ReadFullResponse(request); |
236 } | 239 } |
237 | 240 |
238 } // namespace predictors | 241 } // namespace predictors |
OLD | NEW |