Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(279)

Side by Side Diff: chrome/browser/prerender/prerender_resource_throttle.cc

Issue 2566163002: [PlzNavigate] Add load flags for prefetch navigations (Closed)
Patch Set: Less hacky implementation Created 4 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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/prerender/prerender_resource_throttle.h" 5 #include "chrome/browser/prerender/prerender_resource_throttle.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "base/memory/ref_counted.h" 8 #include "base/memory/ref_counted.h"
9 #include "base/numerics/safe_conversions.h" 9 #include "base/numerics/safe_conversions.h"
10 #include "build/build_config.h" 10 #include "build/build_config.h"
11 #include "chrome/browser/prerender/prerender_final_status.h" 11 #include "chrome/browser/prerender/prerender_final_status.h"
12 #include "chrome/browser/prerender/prerender_manager.h"
13 #include "chrome/browser/prerender/prerender_util.h" 12 #include "chrome/browser/prerender/prerender_util.h"
14 #include "content/public/browser/browser_thread.h" 13 #include "content/public/browser/browser_thread.h"
15 #include "content/public/browser/web_contents.h" 14 #include "content/public/browser/web_contents.h"
15 #include "net/base/load_flags.h"
16 #include "net/http/http_response_headers.h" 16 #include "net/http/http_response_headers.h"
17 #include "net/url_request/redirect_info.h" 17 #include "net/url_request/redirect_info.h"
18 #include "net/url_request/url_request.h" 18 #include "net/url_request/url_request.h"
19 19
20 using content::BrowserThread; 20 using content::BrowserThread;
21 using content::ResourceRequestInfo; 21 using content::ResourceRequestInfo;
22 using content::ResourceType; 22 using content::ResourceType;
23 23
24 namespace prerender { 24 namespace prerender {
25 25
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after
76 base::WeakPtr<PrerenderManager> manager_; 76 base::WeakPtr<PrerenderManager> manager_;
77 }; 77 };
78 78
79 void PrerenderResourceThrottle::OverridePrerenderContentsForTesting( 79 void PrerenderResourceThrottle::OverridePrerenderContentsForTesting(
80 PrerenderContents* contents) { 80 PrerenderContents* contents) {
81 g_prerender_contents_for_testing = contents; 81 g_prerender_contents_for_testing = contents;
82 } 82 }
83 83
84 PrerenderResourceThrottle::PrerenderResourceThrottle(net::URLRequest* request) 84 PrerenderResourceThrottle::PrerenderResourceThrottle(net::URLRequest* request)
85 : request_(request), 85 : request_(request),
86 prerender_mode_(NO_PRERENDER),
86 prerender_throttle_info_(new PrerenderThrottleInfo()) {} 87 prerender_throttle_info_(new PrerenderThrottleInfo()) {}
87 88
88 PrerenderResourceThrottle::~PrerenderResourceThrottle() {} 89 PrerenderResourceThrottle::~PrerenderResourceThrottle() {}
89 90
90 void PrerenderResourceThrottle::WillStartRequest(bool* defer) { 91 void PrerenderResourceThrottle::WillStartRequest(bool* defer) {
91 const content::ResourceRequestInfo* info = 92 const content::ResourceRequestInfo* info =
92 content::ResourceRequestInfo::ForRequest(request_); 93 content::ResourceRequestInfo::ForRequest(request_);
93 *defer = true; 94 *defer = true;
94 BrowserThread::PostTask( 95 BrowserThread::PostTask(
95 BrowserThread::UI, FROM_HERE, 96 BrowserThread::UI, FROM_HERE,
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
132 content::IsResourceTypeFrame(info->GetResourceType()), 133 content::IsResourceTypeFrame(info->GetResourceType()),
133 IsNoStoreResponse(*request_), redirect_count, 134 IsNoStoreResponse(*request_), redirect_count,
134 prerender_throttle_info_)); 135 prerender_throttle_info_));
135 } 136 }
136 137
137 const char* PrerenderResourceThrottle::GetNameForLogging() const { 138 const char* PrerenderResourceThrottle::GetNameForLogging() const {
138 return "PrerenderResourceThrottle"; 139 return "PrerenderResourceThrottle";
139 } 140 }
140 141
141 void PrerenderResourceThrottle::ResumeHandler() { 142 void PrerenderResourceThrottle::ResumeHandler() {
143 if (prerender_mode_ == PREFETCH_ONLY)
mattcary 2016/12/15 15:58:41 Is there any reason to defer setting the load flag
droger 2016/12/15 16:32:36 Done.
144 request_->SetLoadFlags(request_->load_flags() | net::LOAD_PREFETCH);
142 Resume(); 145 Resume();
143 } 146 }
144 147
145 // static 148 // static
146 void PrerenderResourceThrottle::WillStartRequestOnUI( 149 void PrerenderResourceThrottle::WillStartRequestOnUI(
147 const base::WeakPtr<PrerenderResourceThrottle>& throttle, 150 const base::WeakPtr<PrerenderResourceThrottle>& throttle,
148 const std::string& method, 151 const std::string& method,
149 ResourceType resource_type, 152 ResourceType resource_type,
150 const GURL& url, 153 const GURL& url,
151 const ResourceRequestInfo::WebContentsGetter& web_contents_getter, 154 const ResourceRequestInfo::WebContentsGetter& web_contents_getter,
152 scoped_refptr<PrerenderThrottleInfo> prerender_throttle_info) { 155 scoped_refptr<PrerenderThrottleInfo> prerender_throttle_info) {
153 bool cancel = false; 156 bool cancel = false;
154 PrerenderContents* prerender_contents = 157 PrerenderContents* prerender_contents =
155 PrerenderContentsFromGetter(web_contents_getter); 158 PrerenderContentsFromGetter(web_contents_getter);
156 if (prerender_contents) { 159 if (prerender_contents) {
157 DCHECK(prerender_throttle_info); 160 DCHECK(prerender_throttle_info);
158 prerender_throttle_info->Set(prerender_contents->prerender_mode(), 161 prerender_throttle_info->Set(prerender_contents->prerender_mode(),
159 prerender_contents->origin(), 162 prerender_contents->origin(),
160 prerender_contents->prerender_manager()); 163 prerender_contents->prerender_manager());
164 BrowserThread::PostTask(
165 BrowserThread::IO, FROM_HERE,
166 base::Bind(&PrerenderResourceThrottle::set_prerender_mode, throttle,
167 prerender_contents->prerender_mode()));
161 168
162 // Abort any prerenders that spawn requests that use unsupported HTTP 169 // Abort any prerenders that spawn requests that use unsupported HTTP
163 // methods or schemes. 170 // methods or schemes.
164 if (!prerender_contents->IsValidHttpMethod(method)) { 171 if (!prerender_contents->IsValidHttpMethod(method)) {
165 // If this is a full prerender, cancel the prerender in response to 172 // If this is a full prerender, cancel the prerender in response to
166 // invalid requests. For prefetches, cancel invalid requests but keep the 173 // invalid requests. For prefetches, cancel invalid requests but keep the
167 // prefetch going, unless it's the main frame that's invalid. 174 // prefetch going, unless it's the main frame that's invalid.
168 if (prerender_contents->prerender_mode() == FULL_PRERENDER || 175 if (prerender_contents->prerender_mode() == FULL_PRERENDER ||
169 resource_type == content::RESOURCE_TYPE_MAIN_FRAME) { 176 resource_type == content::RESOURCE_TYPE_MAIN_FRAME) {
170 prerender_contents->Destroy(FINAL_STATUS_INVALID_HTTP_METHOD); 177 prerender_contents->Destroy(FINAL_STATUS_INVALID_HTTP_METHOD);
(...skipping 89 matching lines...) Expand 10 before | Expand all | Expand 10 after
260 267
261 // static 268 // static
262 PrerenderContents* PrerenderResourceThrottle::PrerenderContentsFromGetter( 269 PrerenderContents* PrerenderResourceThrottle::PrerenderContentsFromGetter(
263 const ResourceRequestInfo::WebContentsGetter& web_contents_getter) { 270 const ResourceRequestInfo::WebContentsGetter& web_contents_getter) {
264 if (g_prerender_contents_for_testing) 271 if (g_prerender_contents_for_testing)
265 return g_prerender_contents_for_testing; 272 return g_prerender_contents_for_testing;
266 return PrerenderContents::FromWebContents(web_contents_getter.Run()); 273 return PrerenderContents::FromWebContents(web_contents_getter.Run());
267 } 274 }
268 275
269 } // namespace prerender 276 } // namespace prerender
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698