Chromium Code Reviews| 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 |