OLD | NEW |
---|---|
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()); |
mmenke
2012/12/06 22:22:15
Think this is worth a comment, along the lines "Al
gavinp
2012/12/10 17:55:10
Done.
| |
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)) { |
mmenke
2012/12/06 22:22:15
I don't think we should be putting variable declar
| |
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); |
mmenke
2012/12/06 22:22:15
I think this would be much cleaner if we just did:
gavinp
2012/12/10 17:55:10
Done, and I moved around some other code to avoid
| |
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. |
mmenke
2012/12/06 22:22:15
This TODO will no longer work - if a prerender is
gavinp
2012/12/10 17:55:10
Gone. I still am thinking about how to keep all th
| |
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(); |
mmenke
2012/12/06 22:22:15
Hmm...we can now cancel and then navigate aware th
gavinp
2012/12/10 17:55:10
The reason I thought to keep them in was so that e
| |
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 Loading... | |
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(); | |
mmenke
2012/12/06 22:22:15
While this is true for all the places that this fu
gavinp
2012/12/10 17:55:10
Done. I like simple names, and I like names that c
| |
148 return ids_to_handle_map_.end(); | |
149 } | |
150 | |
151 void PrerenderLinkManager::OnPrerenderStart( | |
152 PrerenderHandle* prerender_handle) { | |
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 } | |
mmenke
2012/12/06 22:22:15
Think it would be a little cleaner to have a funct
gavinp
2012/12/10 17:55:10
Done.
| |
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 |
OLD | NEW |