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

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

Issue 5912001: Add PrerenderResourceHandler and hook it into the ResourceDispatcherHost.... (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Remove extra comment. Created 10 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 | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "chrome/browser/prerender/prerender_resource_handler.h"
6
7 #include "chrome/common/resource_response.h"
8 #include "net/base/load_flags.h"
9 #include "net/http/http_response_headers.h"
10 #include "net/url_request/url_request.h"
11
12 PrerenderResourceHandler::PrerenderResourceHandler(
13 ResourceHandler* next_handler,
14 PrerenderManager* prerender_manager)
15 : next_handler_(next_handler),
16 prerender_manager_(prerender_manager),
17 ALLOW_THIS_IN_INITIALIZER_LIST(
18 prerender_callback_(NewCallback(
19 this, &PrerenderResourceHandler::StartPrerender))) {
20 DCHECK(next_handler);
21 DCHECK(prerender_manager);
22 }
23
24 // This constructor is only used from unit tests.
25 PrerenderResourceHandler::PrerenderResourceHandler(
26 ResourceHandler* next_handler,
27 PrerenderCallback* callback)
28 : next_handler_(next_handler),
29 prerender_callback_(callback) {
30 DCHECK(next_handler);
31 }
willchan no longer on Chromium 2010/12/17 21:45:17 indentation
cbentzel 2010/12/19 00:40:56 Done.
32
33 PrerenderResourceHandler::~PrerenderResourceHandler() {
34 }
35
36 bool PrerenderResourceHandler::OnUploadProgress(int request_id,
37 uint64 position,
38 uint64 size) {
39 return next_handler_->OnUploadProgress(request_id, position, size);
40 }
41
42 bool PrerenderResourceHandler::OnRequestRedirected(int request_id,
43 const GURL& url,
44 ResourceResponse* response,
45 bool* defer) {
46 bool will_redirect = next_handler_->OnRequestRedirected(
47 request_id, url, response, defer);
48 if (will_redirect)
49 url_ = url;
50 return will_redirect;
51 }
52
53 bool PrerenderResourceHandler::OnResponseStarted(int request_id,
54 ResourceResponse* response) {
55 if (ShouldPrerender(url_, response)) {
56 BrowserThread::PostTask(
57 BrowserThread::UI,
58 FROM_HERE,
59 NewRunnableMethod(
60 this,
61 &PrerenderResourceHandler::RunCallbackFromUIThread,
62 url_));
63 }
64 return next_handler_->OnResponseStarted(request_id, response);
65 }
66
67 bool PrerenderResourceHandler::OnWillStart(int request_id,
68 const GURL& url,
69 bool* defer) {
70 bool will_start = next_handler_->OnWillStart(request_id, url, defer);
71 if (will_start)
72 url_ = url;
73 return will_start;
74 }
75
76 bool PrerenderResourceHandler::OnWillRead(int request_id,
77 net::IOBuffer** buf,
78 int* buf_size,
79 int min_size) {
80 return next_handler_->OnWillRead(request_id, buf, buf_size, min_size);
81 }
82
83 bool PrerenderResourceHandler::OnReadCompleted(int request_id,
84 int* bytes_read) {
85 return next_handler_->OnReadCompleted(request_id, bytes_read);
86 }
87
88 bool PrerenderResourceHandler::OnResponseCompleted(
89 int request_id,
90 const URLRequestStatus& status,
91 const std::string& security_info) {
92 return next_handler_->OnResponseCompleted(request_id, status, security_info);
93 }
94
95 void PrerenderResourceHandler::OnRequestClosed() {
96 next_handler_->OnRequestClosed();
97 }
98
99 void PrerenderResourceHandler::RunCallbackFromUIThread(const GURL& url) {
100 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
101 prerender_callback_->Run(url);
darin (slow to review) 2010/12/17 19:58:21 there seems to be the assumption here that GET req
cbentzel 2010/12/17 20:03:51 I can add that to ShouldPrerender - this is called
cbentzel 2010/12/19 00:40:56 Now, prerendering only happens if the top-level re
102 }
103
104 void PrerenderResourceHandler::StartPrerender(const GURL& url) {
105 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
106 prerender_manager_->AddPreload(url);
107 }
108
109 // static
110 bool PrerenderResourceHandler::CouldPrerender(const net::URLRequest* request) {
111 return ((request->load_flags() & net::LOAD_PREFETCH) &&
112 request->method() == "GET");
113 }
114
115 // static
116 bool PrerenderResourceHandler::ShouldPrerender(
willchan no longer on Chromium 2010/12/17 21:45:17 I'm not sure why this is a private static function
cbentzel 2010/12/19 00:40:56 Gavin had the same concern. I changed it.
117 const GURL& url,
118 const ResourceResponse* response) {
119 return (url.is_valid() &&
120 (url.SchemeIs("http") || url.SchemeIs("https")) &&
121 response->response_head.headers &&
122 response->response_head.headers->response_code() == 200 &&
123 response->response_head.mime_type == "text/html");
124 }
125
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698