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

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

Issue 10198040: New link rel=prerender api, using WebKit::WebPrerenderingPlatform (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: is this closer? Created 8 years, 7 months 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) 2012 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_link_manager.h"
6
7 #include <limits>
8 #include <queue>
9 #include <utility>
10
11 #include "chrome/browser/prerender/prerender_contents.h"
12 #include "chrome/browser/prerender/prerender_manager.h"
13 #include "chrome/browser/prerender/prerender_manager_factory.h"
14 #include "chrome/browser/profiles/profile.h"
15 #include "content/public/browser/render_view_host.h"
16 #include "content/public/browser/session_storage_namespace.h"
17 #include "content/public/common/referrer.h"
18 #include "googleurl/src/gurl.h"
19 #include "googleurl/src/url_canon.h"
20 #include "ui/gfx/size.h"
21
22 using content::RenderViewHost;
23 using content::SessionStorageNamespace;
24
25 namespace prerender {
26
27 PrerenderLinkManager::PrerenderLinkManager(PrerenderManager* manager)
28 : manager_(manager) {
29 }
30
31 PrerenderLinkManager::~PrerenderLinkManager() {
32 }
33
34 bool PrerenderLinkManager::OnAddPrerender(int child_id,
35 int prerender_id,
36 const GURL& orig_url,
37 const content::Referrer& referrer,
38 const gfx::Size& size,
39 int render_view_route_id) {
40 DVLOG(2) << "OnAddPrerender, child_id = " << child_id
41 << ", prerender_id = " << prerender_id
42 << ", url = " << orig_url.spec();
43 DVLOG(3) << "... render_view_route_id = " << render_view_route_id
44 << ", referrer url = " << referrer.url.spec();
45 // TODO(gavinp): Add tests to ensure fragments work, then remove this fragment
46 // clearing code.
47 url_canon::Replacements<char> replacements;
48 replacements.ClearRef();
49 const GURL url = orig_url.ReplaceComponents(replacements);
50
51 // Unit tests pass in a child_id == -1.
52 RenderViewHost* source_render_view_host = NULL;
53 SessionStorageNamespace* session_storage_namespace = NULL;
54 if (child_id != -1) {
55 source_render_view_host =
56 RenderViewHost::FromID(child_id, render_view_route_id);
57 if (!source_render_view_host || !source_render_view_host->GetView())
58 return false;
59 session_storage_namespace =
60 source_render_view_host->GetSessionStorageNamespace();
61 }
mmenke 2012/05/01 16:23:21 Wonder if this block of code might not be happier
gavinp 2012/05/01 18:50:22 Done.
62
63 if (!manager_->AddPrerenderFromLinkRelPrerender(
64 child_id, render_view_route_id, url, referrer,
65 size, session_storage_namespace)) {
66 return false;
67 }
68 const ChildAndPrerenderIdPair child_and_prerender_id(child_id, prerender_id);
69 DCHECK_EQ(0U, ids_to_url_map_.count(child_and_prerender_id));
70 ids_to_url_map_.insert(std::make_pair(child_and_prerender_id, url));
71 return true;
72 }
73
74 void PrerenderLinkManager::OnCancelPrerender(int child_id, int prerender_id) {
75 DVLOG(2) << "OnCancelPrerender, child_id = " << child_id
76 << ", prerender_id = " << prerender_id;
77 const ChildAndPrerenderIdPair child_and_prerender_id(child_id, prerender_id);
78 IdPairToUrlMap::iterator id_url_iter =
79 ids_to_url_map_.find(child_and_prerender_id);
80 if (id_url_iter == ids_to_url_map_.end()) {
81 DVLOG(5) << "... canceling a prerender that doesn't exist.";
82 return;
83 }
84 const GURL url = id_url_iter->second;
85 ids_to_url_map_.erase(id_url_iter);
86 manager_->MaybeCancelPrerender(url);
mmenke 2012/05/01 16:23:21 Another funky case (Again, just something to think
gavinp 2012/05/01 18:50:22 Yes. That case should be caught by even the simpl
87 }
88
89 void PrerenderLinkManager::OnAbandonPrerender(int child_id, int prerender_id) {
90 DVLOG(2) << "OnAbandonPrerender, child_id = " << child_id
91 << ", prerender_id = " << prerender_id;
92 // TODO(gavinp,cbentzel): Implement reasonable behaviour for
93 // navigation away from launcher.
mmenke 2012/05/01 16:23:21 You had a comment here before on why there's no ch
gavinp 2012/05/01 18:50:22 That comment got mooted by dominich's earlier sugg
mmenke 2012/05/02 15:02:52 Oh, right. I saw the DVLOG for that case in OnCan
94 const ChildAndPrerenderIdPair child_and_prerender_id(child_id, prerender_id);
95 ids_to_url_map_.erase(child_and_prerender_id);
96 }
97
98 void PrerenderLinkManager::OnChannelClosing(int child_id) {
99 DVLOG(2) << "OnChannelClosing, child id = " << child_id;
100 const ChildAndPrerenderIdPair child_and_minimum_prerender_id(
101 child_id, std::numeric_limits<int>::min());
102 const ChildAndPrerenderIdPair child_and_maximum_prerender_id(
103 child_id, std::numeric_limits<int>::max());
104 std::queue<int> prerender_ids_to_abandon;
105 for (IdPairToUrlMap::iterator
106 i = ids_to_url_map_.lower_bound(child_and_minimum_prerender_id),
107 e = ids_to_url_map_.upper_bound(child_and_maximum_prerender_id);
108 i != e; ++i) {
109 prerender_ids_to_abandon.push(i->first.second);
110 }
111 while (!prerender_ids_to_abandon.empty()) {
112 DVLOG(4) << "---> abandon prerender_id = "
113 << prerender_ids_to_abandon.front();
114 OnAbandonPrerender(child_id, prerender_ids_to_abandon.front());
115 prerender_ids_to_abandon.pop();
116 }
117 }
118
119 bool PrerenderLinkManager::IsEmpty() const {
120 return ids_to_url_map_.empty();
121 }
122
123 } // namespace prerender
124
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698