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/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 Loading... | |
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 Loading... | |
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 |
OLD | NEW |