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

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

Issue 11316311: Make PrerenderHandle an observer of PrerenderContents. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebase trunk & add upstream remediation Created 8 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
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 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 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_link_manager.h" 5 #include "chrome/browser/prerender/prerender_link_manager.h"
6 6
7 #include <limits> 7 #include <limits>
8 #include <queue> 8 #include <queue>
9 #include <utility> 9 #include <utility>
10 10
11 #include "chrome/browser/prerender/prerender_contents.h" 11 #include "chrome/browser/prerender/prerender_contents.h"
12 #include "chrome/browser/prerender/prerender_handle.h" 12 #include "chrome/browser/prerender/prerender_handle.h"
13 #include "chrome/browser/prerender/prerender_manager.h" 13 #include "chrome/browser/prerender/prerender_manager.h"
14 #include "chrome/browser/prerender/prerender_manager_factory.h" 14 #include "chrome/browser/prerender/prerender_manager_factory.h"
15 #include "chrome/browser/profiles/profile.h" 15 #include "chrome/browser/profiles/profile.h"
16 #include "chrome/common/prerender_messages.h"
17 #include "content/public/browser/render_process_host.h"
16 #include "content/public/browser/render_view_host.h" 18 #include "content/public/browser/render_view_host.h"
17 #include "content/public/browser/session_storage_namespace.h" 19 #include "content/public/browser/session_storage_namespace.h"
18 #include "content/public/common/referrer.h" 20 #include "content/public/common/referrer.h"
19 #include "googleurl/src/gurl.h" 21 #include "googleurl/src/gurl.h"
20 #include "ui/gfx/size.h" 22 #include "ui/gfx/size.h"
21 23
22 using content::RenderViewHost; 24 using content::RenderViewHost;
23 using content::SessionStorageNamespace; 25 using content::SessionStorageNamespace;
24 26
25 namespace prerender { 27 namespace prerender {
26 28
27 PrerenderLinkManager::PrerenderLinkManager(PrerenderManager* manager) 29 PrerenderLinkManager::PrerenderLinkManager(PrerenderManager* manager)
28 : manager_(manager) { 30 : manager_(manager) {
29 } 31 }
30 32
31 PrerenderLinkManager::~PrerenderLinkManager() { 33 PrerenderLinkManager::~PrerenderLinkManager() {
32 for (IdPairToPrerenderHandleMap::iterator it = ids_to_handle_map_.begin(); 34 for (IdPairToPrerenderHandleMap::iterator it = ids_to_handle_map_.begin();
33 it != ids_to_handle_map_.end(); 35 it != ids_to_handle_map_.end();
34 ++it) { 36 ++it) {
35 PrerenderHandle* prerender_handle = it->second; 37 PrerenderHandle* prerender_handle = it->second;
36 prerender_handle->OnCancel(); 38 DCHECK(!prerender_handle->IsValid());
37 delete prerender_handle; 39 delete prerender_handle;
38 } 40 }
39 } 41 }
40 42
41 bool PrerenderLinkManager::OnAddPrerender(int child_id, 43 bool PrerenderLinkManager::OnAddPrerender(int child_id,
42 int prerender_id, 44 int prerender_id,
43 const GURL& url, 45 const GURL& url,
44 const content::Referrer& referrer, 46 const content::Referrer& referrer,
45 const gfx::Size& size, 47 const gfx::Size& size,
46 int render_view_route_id) { 48 int render_view_route_id) {
47 DVLOG(2) << "OnAddPrerender, child_id = " << child_id 49 DVLOG(2) << "OnAddPrerender, child_id = " << child_id
48 << ", prerender_id = " << prerender_id 50 << ", prerender_id = " << prerender_id
49 << ", url = " << url.spec(); 51 << ", url = " << url.spec();
50 DVLOG(3) << "... referrer url = " << referrer.url.spec() 52 DVLOG(3) << "... referrer url = " << referrer.url.spec()
51 << ", size = (" << size.width() << ", " << size.height() << ")" 53 << ", size = (" << size.width() << ", " << size.height() << ")"
52 << ", render_view_route_id = " << render_view_route_id; 54 << ", render_view_route_id = " << render_view_route_id;
53 55
54 const ChildAndPrerenderIdPair child_and_prerender_id(child_id, prerender_id); 56 const ChildAndPrerenderIdPair child_and_prerender_id(child_id, prerender_id);
55 DCHECK_EQ(0U, ids_to_handle_map_.count(child_and_prerender_id)); 57 DCHECK_EQ(0u, ids_to_handle_map_.count(child_and_prerender_id));
56 58
57 scoped_ptr<PrerenderHandle> prerender_handle( 59 if (PrerenderHandle* prerender_handle = manager_->
58 manager_->AddPrerenderFromLinkRelPrerender( 60 AddPrerenderFromLinkRelPrerender(child_id, render_view_route_id,
59 child_id, render_view_route_id, url, referrer, size)); 61 url, referrer, size)) {
60 if (prerender_handle.get()) {
61 std::pair<IdPairToPrerenderHandleMap::iterator, bool> insert_result = 62 std::pair<IdPairToPrerenderHandleMap::iterator, bool> insert_result =
62 ids_to_handle_map_.insert(std::make_pair( 63 ids_to_handle_map_.insert(std::make_pair(child_and_prerender_id,
63 child_and_prerender_id, static_cast<PrerenderHandle*>(NULL))); 64 prerender_handle));
64 DCHECK(insert_result.second); 65 DCHECK(insert_result.second);
65 delete insert_result.first->second; 66 // If we are given a prerender that is already prerendering, we have missed
66 insert_result.first->second = prerender_handle.release(); 67 // the start event.
68 if (prerender_handle->IsPrerendering())
69 OnPrerenderStart(prerender_handle);
70 prerender_handle->AddObserver(this);
67 return true; 71 return true;
68 } 72 }
69 return false; 73 return false;
70 } 74 }
71 75
72 // TODO(gavinp): Once an observer interface is provided down to the WebKit 76 // TODO(gavinp): Once an observer interface is provided down to the WebKit
73 // layer, we should add DCHECK_NE(0L, ids_to_url_map_.count(...)) to both 77 // layer, we should add DCHECK_NE(0L, ids_to_url_map_.count(...)) to both
74 // OnCancelPrerender and OnAbandonPrerender. We can't do this now, since 78 // OnCancelPrerender and OnAbandonPrerender. We can't do this now, since
75 // the WebKit layer isn't even aware if we didn't add the prerender to the map 79 // the WebKit layer isn't even aware if we didn't add the prerender to the map
76 // in OnAddPrerender above. 80 // in OnAddPrerender above.
77 void PrerenderLinkManager::OnCancelPrerender(int child_id, int prerender_id) { 81 void PrerenderLinkManager::OnCancelPrerender(int child_id, int prerender_id) {
78 DVLOG(2) << "OnCancelPrerender, child_id = " << child_id 82 DVLOG(2) << "OnCancelPrerender, child_id = " << child_id
79 << ", prerender_id = " << prerender_id; 83 << ", prerender_id = " << prerender_id;
80 const ChildAndPrerenderIdPair child_and_prerender_id(child_id, prerender_id); 84 const ChildAndPrerenderIdPair child_and_prerender_id(child_id, prerender_id);
81 IdPairToPrerenderHandleMap::iterator id_to_handle_iter = 85 IdPairToPrerenderHandleMap::iterator id_to_handle_iter =
82 ids_to_handle_map_.find(child_and_prerender_id); 86 ids_to_handle_map_.find(child_and_prerender_id);
83 if (id_to_handle_iter == ids_to_handle_map_.end()) { 87 if (id_to_handle_iter == ids_to_handle_map_.end()) {
84 DVLOG(5) << "... canceling a prerender that doesn't exist."; 88 DVLOG(5) << "... canceling a prerender that doesn't exist.";
85 return; 89 return;
86 } 90 }
87 PrerenderHandle* prerender_handle = id_to_handle_iter->second; 91 PrerenderHandle* prerender_handle = id_to_handle_iter->second;
88 prerender_handle->OnCancel(); 92 prerender_handle->OnCancel();
89 RemovePrerender(id_to_handle_iter);
90 } 93 }
91 94
92 void PrerenderLinkManager::OnAbandonPrerender(int child_id, int prerender_id) { 95 void PrerenderLinkManager::OnAbandonPrerender(int child_id, int prerender_id) {
93 DVLOG(2) << "OnAbandonPrerender, child_id = " << child_id 96 DVLOG(2) << "OnAbandonPrerender, child_id = " << child_id
94 << ", prerender_id = " << prerender_id; 97 << ", prerender_id = " << prerender_id;
95 const ChildAndPrerenderIdPair child_and_prerender_id(child_id, prerender_id); 98 const ChildAndPrerenderIdPair child_and_prerender_id(child_id, prerender_id);
96 IdPairToPrerenderHandleMap::iterator id_to_handle_iter = 99 IdPairToPrerenderHandleMap::iterator id_to_handle_iter =
97 ids_to_handle_map_.find(child_and_prerender_id); 100 ids_to_handle_map_.find(child_and_prerender_id);
98 if (id_to_handle_iter == ids_to_handle_map_.end()) 101 if (id_to_handle_iter == ids_to_handle_map_.end())
99 return; 102 return;
100 PrerenderHandle* prerender_handle = id_to_handle_iter->second; 103 PrerenderHandle* prerender_handle = id_to_handle_iter->second;
101 prerender_handle->OnNavigateAway(); 104 prerender_handle->OnNavigateAway();
102 RemovePrerender(id_to_handle_iter);
103 } 105 }
104 106
105 void PrerenderLinkManager::OnChannelClosing(int child_id) { 107 void PrerenderLinkManager::OnChannelClosing(int child_id) {
106 DVLOG(2) << "OnChannelClosing, child id = " << child_id; 108 DVLOG(2) << "OnChannelClosing, child id = " << child_id;
107 const ChildAndPrerenderIdPair child_and_minimum_prerender_id( 109 const ChildAndPrerenderIdPair child_and_minimum_prerender_id(
108 child_id, std::numeric_limits<int>::min()); 110 child_id, std::numeric_limits<int>::min());
109 const ChildAndPrerenderIdPair child_and_maximum_prerender_id( 111 const ChildAndPrerenderIdPair child_and_maximum_prerender_id(
110 child_id, std::numeric_limits<int>::max()); 112 child_id, std::numeric_limits<int>::max());
111 std::queue<int> prerender_ids_to_abandon; 113 std::queue<int> prerender_ids_to_abandon;
112 for (IdPairToPrerenderHandleMap::iterator 114 for (IdPairToPrerenderHandleMap::iterator
(...skipping 14 matching lines...) Expand all
127 return ids_to_handle_map_.empty(); 129 return ids_to_handle_map_.empty();
128 } 130 }
129 131
130 void PrerenderLinkManager::RemovePrerender( 132 void PrerenderLinkManager::RemovePrerender(
131 const IdPairToPrerenderHandleMap::iterator& id_to_handle_iter) { 133 const IdPairToPrerenderHandleMap::iterator& id_to_handle_iter) {
132 PrerenderHandle* prerender_handle = id_to_handle_iter->second; 134 PrerenderHandle* prerender_handle = id_to_handle_iter->second;
133 delete prerender_handle; 135 delete prerender_handle;
134 ids_to_handle_map_.erase(id_to_handle_iter); 136 ids_to_handle_map_.erase(id_to_handle_iter);
135 } 137 }
136 138
139 PrerenderLinkManager::IdPairToPrerenderHandleMap::iterator
140 PrerenderLinkManager::FindPrerenderHandle(
141 PrerenderHandle* prerender_handle) {
142 for (IdPairToPrerenderHandleMap::iterator it = ids_to_handle_map_.begin();
143 it != ids_to_handle_map_.end(); ++it) {
144 if (it->second == prerender_handle)
145 return it;
146 }
147 NOTREACHED();
148 return ids_to_handle_map_.end();
149 }
150
151 void PrerenderLinkManager::OnPrerenderStart(
152 PrerenderHandle* prerender_handle) {
mmenke 2012/12/07 17:59:29 Think it's worth mentioning that this is called fr
gavinp 2012/12/10 17:55:10 Done. I'm not super happy about this either; perh
153 ChildAndPrerenderIdPair child_and_prerender_id_pair =
154 FindPrerenderHandle(prerender_handle)->first;
155 const int child_id = child_and_prerender_id_pair.first;
156 const int prerender_id = child_and_prerender_id_pair.second;
157
158 if (content::RenderProcessHost* render_process_host =
159 content::RenderProcessHost::FromID(child_id)) {
160 render_process_host->Send(new PrerenderMsg_OnPrerenderStart(prerender_id));
161 }
162 }
163
164 void PrerenderLinkManager::OnPrerenderAddAlias(
165 PrerenderHandle* prerender_handle,
166 const GURL& alias_url) {
167 ChildAndPrerenderIdPair child_and_prerender_id_pair =
168 FindPrerenderHandle(prerender_handle)->first;
169 const int child_id = child_and_prerender_id_pair.first;
170 const int prerender_id = child_and_prerender_id_pair.second;
171
172 if (content::RenderProcessHost* render_process_host =
173 content::RenderProcessHost::FromID(child_id)) {
174 render_process_host->Send(new PrerenderMsg_OnPrerenderAddAlias(prerender_id,
175 alias_url));
176 }
177 }
178
179 void PrerenderLinkManager::OnPrerenderStop(
180 PrerenderHandle* prerender_handle) {
181 IdPairToPrerenderHandleMap::iterator
182 it = FindPrerenderHandle(prerender_handle);
183 ChildAndPrerenderIdPair child_and_prerender_id_pair = it->first;
184 const int child_id = child_and_prerender_id_pair.first;
185 const int prerender_id = child_and_prerender_id_pair.second;
186
187 if (content::RenderProcessHost* render_process_host =
188 content::RenderProcessHost::FromID(child_id)) {
189 render_process_host->Send(new PrerenderMsg_OnPrerenderStop(prerender_id));
190 }
191 RemovePrerender(it);
192 }
193
137 } // namespace prerender 194 } // namespace prerender
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698