Chromium Code Reviews| OLD | NEW |
|---|---|
| (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 } | |
| 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 // DCHECK(url_.is_valid()); | |
|
gavinp
2010/12/17 16:15:33
lose the comment.
cbentzel
2010/12/17 16:23:21
Done.
| |
| 57 BrowserThread::PostTask( | |
| 58 BrowserThread::UI, | |
| 59 FROM_HERE, | |
| 60 NewRunnableMethod( | |
| 61 this, | |
| 62 &PrerenderResourceHandler::RunCallbackFromUIThread, | |
| 63 url_)); | |
| 64 } | |
| 65 return next_handler_->OnResponseStarted(request_id, response); | |
| 66 } | |
| 67 | |
| 68 bool PrerenderResourceHandler::OnWillStart(int request_id, | |
| 69 const GURL& url, | |
| 70 bool* defer) { | |
| 71 bool will_start = next_handler_->OnWillStart(request_id, url, defer); | |
| 72 if (will_start) | |
| 73 url_ = url; | |
| 74 return will_start; | |
| 75 } | |
| 76 | |
| 77 bool PrerenderResourceHandler::OnWillRead(int request_id, | |
| 78 net::IOBuffer** buf, | |
| 79 int* buf_size, | |
| 80 int min_size) { | |
| 81 return next_handler_->OnWillRead(request_id, buf, buf_size, min_size); | |
| 82 } | |
| 83 | |
| 84 bool PrerenderResourceHandler::OnReadCompleted(int request_id, | |
| 85 int* bytes_read) { | |
| 86 return next_handler_->OnReadCompleted(request_id, bytes_read); | |
| 87 } | |
| 88 | |
| 89 bool PrerenderResourceHandler::OnResponseCompleted( | |
| 90 int request_id, | |
| 91 const URLRequestStatus& status, | |
| 92 const std::string& security_info) { | |
| 93 return next_handler_->OnResponseCompleted(request_id, status, security_info); | |
| 94 } | |
| 95 | |
| 96 void PrerenderResourceHandler::OnRequestClosed() { | |
| 97 next_handler_->OnRequestClosed(); | |
| 98 } | |
| 99 | |
| 100 void PrerenderResourceHandler::RunCallbackFromUIThread(const GURL& url) { | |
| 101 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | |
| 102 prerender_callback_->Run(url); | |
| 103 } | |
| 104 | |
| 105 void PrerenderResourceHandler::StartPrerender(const GURL& url) { | |
| 106 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | |
| 107 prerender_manager_->AddPreload(url); | |
| 108 } | |
| 109 | |
| 110 // static | |
| 111 bool PrerenderResourceHandler::CouldPrerender(const net::URLRequest* request) { | |
| 112 return ((request->load_flags() & net::LOAD_PREFETCH) && | |
| 113 request->method() == "GET"); | |
| 114 } | |
| 115 | |
| 116 // static | |
| 117 bool PrerenderResourceHandler::ShouldPrerender( | |
|
gavinp
2010/12/17 16:15:33
anon namespace?
cbentzel
2010/12/17 16:23:21
Huh? These are static methods on PrerenderResource
| |
| 118 const GURL& url, | |
| 119 const ResourceResponse* response) { | |
| 120 return (url.is_valid() && | |
| 121 (url.SchemeIs("http") || url.SchemeIs("https")) && | |
| 122 response->response_head.headers && | |
| 123 response->response_head.headers->response_code() == 200 && | |
| 124 response->response_head.mime_type == "text/html"); | |
| 125 } | |
| 126 | |
| OLD | NEW |