summaryrefslogtreecommitdiffstats
path: root/content/browser
diff options
context:
space:
mode:
authorgavinp@chromium.org <gavinp@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-05-24 19:19:47 +0000
committergavinp@chromium.org <gavinp@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-05-24 19:19:47 +0000
commit61a99dd8b78f552519041f4cdcdcea4d97101e88 (patch)
treef382701426e85140be8f42237731ae0f7ab04f96 /content/browser
parent7cde9091043bf12f967688962414f0e129ea7cc7 (diff)
downloadchromium_src-61a99dd8b78f552519041f4cdcdcea4d97101e88.zip
chromium_src-61a99dd8b78f552519041f4cdcdcea4d97101e88.tar.gz
chromium_src-61a99dd8b78f552519041f4cdcdcea4d97101e88.tar.bz2
Handle <link rel=prerender> in chrome.
This new link rel type is being used for the prerendering experiment instead of prefetch; this CL depends on webkit patch https://bugs.webkit.org/show_bug.cgi?id=61297 landing, but, together with that patch, chrome properly interprets and responds to link rel=prerender to launch prerendering. BUG=none TEST=PrerenderBrowserTest.* Review URL: http://codereview.chromium.org/6966016 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@86465 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'content/browser')
-rw-r--r--content/browser/renderer_host/resource_dispatcher_host.cc28
1 files changed, 17 insertions, 11 deletions
diff --git a/content/browser/renderer_host/resource_dispatcher_host.cc b/content/browser/renderer_host/resource_dispatcher_host.cc
index c92d1d6..17633a8 100644
--- a/content/browser/renderer_host/resource_dispatcher_host.cc
+++ b/content/browser/renderer_host/resource_dispatcher_host.cc
@@ -437,9 +437,7 @@ void ResourceDispatcherHost::BeginRequest(
child_id, route_id);
// Handle a PREFETCH resource type. If prefetch is disabled, squelch the
- // request. If prerendering is enabled, trigger a prerender for the URL
- // and abort the request, to prevent double-gets. Otherwise, do a normal
- // prefetch.
+ // request. Otherwise, do a normal request to warm the cache.
if (request_data.resource_type == ResourceType::PREFETCH) {
// All PREFETCH requests should be GETs, but be defensive about it.
if (request_data.method != "GET") {
@@ -450,20 +448,26 @@ void ResourceDispatcherHost::BeginRequest(
AbortRequestBeforeItStarts(filter_, sync_result, route_id, request_id);
return;
}
+ // Otherwise, treat like a normal request, and fall-through.
+ }
+
+ // Handle a PRERENDER motivated request. Very similar to rel=prefetch, these
+ // rel=prerender requests instead launch an early render of the entire page.
+ if (request_data.resource_type == ResourceType::PRERENDER) {
if (prerender::PrerenderManager::IsPrerenderingPossible()) {
BrowserThread::PostTask(
BrowserThread::UI, FROM_HERE,
- NewRunnableFunction(prerender::HandlePrefetchTag,
+ NewRunnableFunction(prerender::HandleTag,
resource_context.prerender_manager(),
child_id,
route_id,
request_data.url,
referrer,
is_prerendering));
- AbortRequestBeforeItStarts(filter_, sync_result, route_id, request_id);
- return;
}
- // Otherwise, treat like a normal request, and fall-through.
+ // Prerendering or not, this request should stop.
+ AbortRequestBeforeItStarts(filter_, sync_result, route_id, request_id);
+ return;
}
// Abort any prerenders that spawn requests that use invalid HTTP methods.
@@ -524,7 +528,7 @@ void ResourceDispatcherHost::BeginRequest(
}
if (is_prerendering)
- load_flags |= net::LOAD_PRERENDER;
+ load_flags |= net::LOAD_PRERENDERING;
if (sync_result)
load_flags |= net::LOAD_IGNORE_LIMITS;
@@ -1981,7 +1985,7 @@ net::RequestPriority ResourceDispatcherHost::DetermineRequestPriority(
// * How useful is the page to the user if this resource is not loaded yet.
// Prerender-motivated requests should be made at IDLE.
- if (load_flags & net::LOAD_PRERENDER)
+ if (load_flags & net::LOAD_PRERENDERING)
return net::IDLE;
switch (type) {
@@ -2021,9 +2025,11 @@ net::RequestPriority ResourceDispatcherHost::DetermineRequestPriority(
case ResourceType::FAVICON:
return net::LOWEST;
- // Prefetches are at a lower priority than even LOWEST, since they
- // are not even required for rendering of the current page.
+ // Prefetches and prerenders are at a lower priority than even
+ // LOWEST, since they are not even required for rendering of the
+ // current page.
case ResourceType::PREFETCH:
+ case ResourceType::PRERENDER:
return net::IDLE;
default: