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

Side by Side Diff: chrome/renderer/prerender/prerender_dispatcher.cc

Issue 15027009: Broadcast prerender URLs to all render processes. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: More unit tests Created 7 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
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/renderer/prerender/prerender_dispatcher.h" 5 #include "chrome/renderer/prerender/prerender_dispatcher.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "chrome/common/prerender_messages.h" 8 #include "chrome/common/prerender_messages.h"
9 #include "chrome/renderer/prerender/prerender_extra_data.h" 9 #include "chrome/renderer/prerender/prerender_extra_data.h"
10 #include "content/public/common/referrer.h" 10 #include "content/public/common/referrer.h"
(...skipping 25 matching lines...) Expand all
36 DCHECK_NE(0u, prerenders_.count(prerender_id)); 36 DCHECK_NE(0u, prerenders_.count(prerender_id));
37 std::map<int, WebPrerender>::iterator it = prerenders_.find(prerender_id); 37 std::map<int, WebPrerender>::iterator it = prerenders_.find(prerender_id);
38 38
39 WebPrerender& prerender = it->second; 39 WebPrerender& prerender = it->second;
40 40
41 // The prerender should only be null in unit tests. 41 // The prerender should only be null in unit tests.
42 if (prerender.isNull()) 42 if (prerender.isNull())
43 return; 43 return;
44 44
45 prerender.didStartPrerender(); 45 prerender.didStartPrerender();
46 OnPrerenderAddAlias(prerender_id, prerender.url());
47 } 46 }
48 47
49 void PrerenderDispatcher::OnPrerenderStopLoading(int prerender_id) { 48 void PrerenderDispatcher::OnPrerenderStopLoading(int prerender_id) {
50 DCHECK_NE(0u, prerenders_.count(prerender_id)); 49 DCHECK_NE(0u, prerenders_.count(prerender_id));
51 std::map<int, WebPrerender>::iterator it = prerenders_.find(prerender_id); 50 std::map<int, WebPrerender>::iterator it = prerenders_.find(prerender_id);
52 51
53 WebPrerender& prerender = it->second; 52 WebPrerender& prerender = it->second;
54 DCHECK(!prerender.isNull()) 53 DCHECK(!prerender.isNull())
55 << "OnPrerenderStopLoading shouldn't be called from a unit test, the only" 54 << "OnPrerenderStopLoading shouldn't be called from a unit test, the only"
56 << "context in which a WebPrerender in the dispatcher can be null."; 55 << "context in which a WebPrerender in the dispatcher can be null.";
57 56
58 prerender.didSendLoadForPrerender(); 57 prerender.didSendLoadForPrerender();
59 } 58 }
60 59
61 void PrerenderDispatcher::OnPrerenderAddAlias(int prerender_id, 60 void PrerenderDispatcher::OnPrerenderAddAlias(const GURL& alias) {
gavinp 2013/05/13 16:30:27 Initially I wanted to ask for: DCHECK_LT(0, prere
cbentzel 2013/05/13 22:33:05 Yes, that's why it doesn't work.
62 const GURL& url) { 61 running_prerender_urls_.insert(alias);
63 DCHECK_NE(0u, prerenders_.count(prerender_id)); 62 }
64 running_prerender_urls_.insert( 63
65 std::multimap<GURL, int>::value_type(url, prerender_id)); 64 void PrerenderDispatcher::OnPrerenderRemoveAliases(
65 const std::vector<GURL>& aliases) {
66 for (size_t i = 0; i < aliases.size(); ++i) {
67 std::multiset<GURL>::iterator it = running_prerender_urls_.find(aliases[i]);
68 if (it != running_prerender_urls_.end()) {
69 running_prerender_urls_.erase(it);
70 }
71 }
66 } 72 }
67 73
68 void PrerenderDispatcher::OnPrerenderStop(int prerender_id) { 74 void PrerenderDispatcher::OnPrerenderStop(int prerender_id) {
69 DCHECK_NE(0u, prerenders_.count(prerender_id)); 75 DCHECK_NE(0u, prerenders_.count(prerender_id));
70 WebPrerender& prerender = prerenders_[prerender_id]; 76 WebPrerender& prerender = prerenders_[prerender_id];
71 77
72 // The prerender should only be null in unit tests. 78 // The prerender should only be null in unit tests.
73 if (!prerender.isNull()) 79 if (!prerender.isNull())
74 prerender.didStopPrerender(); 80 prerender.didStopPrerender();
75 81
76 // TODO(cbentzel): We'd also want to send the map of active prerenders when 82 // TODO(cbentzel): We'd also want to send the map of active prerenders when
77 // creating a new render process, so the Add/Remove go relative to that. 83 // creating a new render process, so the Add/Remove go relative to that.
78 // This may not be that big of a deal in practice, since the newly created tab 84 // This may not be that big of a deal in practice, since the newly created tab
79 // is unlikely to go to the prerendered page. 85 // is unlikely to go to the prerendered page.
80 prerenders_.erase(prerender_id); 86 prerenders_.erase(prerender_id);
81
82 std::multimap<GURL, int>::iterator it = running_prerender_urls_.begin();
83 while (it != running_prerender_urls_.end()) {
84 std::multimap<GURL, int>::iterator next = it;
85 ++next;
86
87 if (it->second == prerender_id)
88 running_prerender_urls_.erase(it);
89
90 it = next;
91 }
92 } 87 }
93 88
94 bool PrerenderDispatcher::OnControlMessageReceived( 89 bool PrerenderDispatcher::OnControlMessageReceived(
95 const IPC::Message& message) { 90 const IPC::Message& message) {
96 bool handled = true; 91 bool handled = true;
97 IPC_BEGIN_MESSAGE_MAP(PrerenderDispatcher, message) 92 IPC_BEGIN_MESSAGE_MAP(PrerenderDispatcher, message)
98 IPC_MESSAGE_HANDLER(PrerenderMsg_OnPrerenderStart, OnPrerenderStart) 93 IPC_MESSAGE_HANDLER(PrerenderMsg_OnPrerenderStart, OnPrerenderStart)
99 IPC_MESSAGE_HANDLER(PrerenderMsg_OnPrerenderStopLoading, 94 IPC_MESSAGE_HANDLER(PrerenderMsg_OnPrerenderStopLoading,
100 OnPrerenderStopLoading) 95 OnPrerenderStopLoading)
101 IPC_MESSAGE_HANDLER(PrerenderMsg_OnPrerenderAddAlias, OnPrerenderAddAlias) 96 IPC_MESSAGE_HANDLER(PrerenderMsg_OnPrerenderAddAlias, OnPrerenderAddAlias)
97 IPC_MESSAGE_HANDLER(PrerenderMsg_OnPrerenderRemoveAliases,
98 OnPrerenderRemoveAliases)
102 IPC_MESSAGE_HANDLER(PrerenderMsg_OnPrerenderStop, OnPrerenderStop) 99 IPC_MESSAGE_HANDLER(PrerenderMsg_OnPrerenderStop, OnPrerenderStop)
103 IPC_MESSAGE_UNHANDLED(handled = false) 100 IPC_MESSAGE_UNHANDLED(handled = false)
104 IPC_END_MESSAGE_MAP() 101 IPC_END_MESSAGE_MAP()
105 102
106 return handled; 103 return handled;
107 } 104 }
108 105
109 void PrerenderDispatcher::add(const WebPrerender& prerender) { 106 void PrerenderDispatcher::add(const WebPrerender& prerender) {
110 const PrerenderExtraData& extra_data = 107 const PrerenderExtraData& extra_data =
111 PrerenderExtraData::FromPrerender(prerender); 108 PrerenderExtraData::FromPrerender(prerender);
(...skipping 19 matching lines...) Expand all
131 } 128 }
132 129
133 void PrerenderDispatcher::abandon(const WebPrerender& prerender) { 130 void PrerenderDispatcher::abandon(const WebPrerender& prerender) {
134 const PrerenderExtraData& extra_data = 131 const PrerenderExtraData& extra_data =
135 PrerenderExtraData::FromPrerender(prerender); 132 PrerenderExtraData::FromPrerender(prerender);
136 content::RenderThread::Get()->Send( 133 content::RenderThread::Get()->Send(
137 new PrerenderHostMsg_AbandonLinkRelPrerender(extra_data.prerender_id())); 134 new PrerenderHostMsg_AbandonLinkRelPrerender(extra_data.prerender_id()));
138 } 135 }
139 136
140 } // namespace prerender 137 } // namespace prerender
OLDNEW
« no previous file with comments | « chrome/renderer/prerender/prerender_dispatcher.h ('k') | chrome/renderer/prerender/prerender_dispatcher_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698