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 16 matching lines...) Expand all Loading... | |
27 PrerenderDispatcher::~PrerenderDispatcher() { | 27 PrerenderDispatcher::~PrerenderDispatcher() { |
28 WebPrerenderingSupport::shutdown(); | 28 WebPrerenderingSupport::shutdown(); |
29 } | 29 } |
30 | 30 |
31 bool PrerenderDispatcher::IsPrerenderURL(const GURL& url) const { | 31 bool PrerenderDispatcher::IsPrerenderURL(const GURL& url) const { |
32 return running_prerender_urls_.count(url) >= 1; | 32 return running_prerender_urls_.count(url) >= 1; |
33 } | 33 } |
34 | 34 |
35 void PrerenderDispatcher::OnPrerenderStart(int prerender_id) { | 35 void PrerenderDispatcher::OnPrerenderStart(int prerender_id) { |
36 DCHECK_NE(0u, prerenders_.count(prerender_id)); | 36 DCHECK_NE(0u, prerenders_.count(prerender_id)); |
37 std::map<int, GURL>::iterator it = prerenders_.find(prerender_id); | 37 std::map<int, WebPrerender>::iterator it = prerenders_.find(prerender_id); |
38 const GURL& url = it->second; | 38 |
39 WebPrerender& prerender = it->second; | |
40 | |
41 // The prerender should only be null in unit tests. | |
42 if (prerender.isNull()) | |
43 return; | |
44 | |
45 prerender.didStartPrerender(); | |
39 running_prerender_urls_.insert( | 46 running_prerender_urls_.insert( |
40 std::multimap<GURL, int>::value_type(url, prerender_id)); | 47 std::multimap<GURL, int>::value_type(prerender.url(), prerender_id)); |
mmenke
2012/12/17 17:08:18
nit: Suggest using OnPrerenderAddAlias here. Mak
gavinp
2012/12/17 20:34:02
Done.
| |
41 } | 48 } |
42 | 49 |
43 void PrerenderDispatcher::OnPrerenderAddAlias(int prerender_id, | 50 void PrerenderDispatcher::OnPrerenderAddAlias(int prerender_id, |
44 const GURL& url) { | 51 const GURL& url) { |
45 DCHECK_NE(0u, prerenders_.count(prerender_id)); | 52 DCHECK_NE(0u, prerenders_.count(prerender_id)); |
46 running_prerender_urls_.insert( | 53 running_prerender_urls_.insert( |
47 std::multimap<GURL, int>::value_type(url, prerender_id)); | 54 std::multimap<GURL, int>::value_type(url, prerender_id)); |
48 } | 55 } |
49 | 56 |
50 void PrerenderDispatcher::OnPrerenderStop(int prerender_id) { | 57 void PrerenderDispatcher::OnPrerenderStop(int prerender_id) { |
51 DCHECK_NE(0u, prerenders_.count(prerender_id)); | 58 DCHECK_NE(0u, prerenders_.count(prerender_id)); |
59 WebPrerender& prerender = prerenders_[prerender_id]; | |
60 | |
61 // The prerender should only be null in unit tests. | |
62 if (!prerender.isNull()) | |
63 prerender.didStopPrerender(); | |
52 | 64 |
53 // TODO(cbentzel): We'd also want to send the map of active prerenders when | 65 // TODO(cbentzel): We'd also want to send the map of active prerenders when |
54 // creating a new render process, so the Add/Remove go relative to that. | 66 // creating a new render process, so the Add/Remove go relative to that. |
55 // This may not be that big of a deal in practice, since the newly created tab | 67 // This may not be that big of a deal in practice, since the newly created tab |
56 // is unlikely to go to the prerendered page. | 68 // is unlikely to go to the prerendered page. |
57 prerenders_.erase(prerender_id); | 69 prerenders_.erase(prerender_id); |
58 | 70 |
59 std::multimap<GURL, int>::iterator it = running_prerender_urls_.begin(); | 71 std::multimap<GURL, int>::iterator it = running_prerender_urls_.begin(); |
60 while (it != running_prerender_urls_.end()) { | 72 while (it != running_prerender_urls_.end()) { |
61 std::multimap<GURL, int>::iterator next = it; | 73 std::multimap<GURL, int>::iterator next = it; |
(...skipping 12 matching lines...) Expand all Loading... | |
74 IPC_BEGIN_MESSAGE_MAP(PrerenderDispatcher, message) | 86 IPC_BEGIN_MESSAGE_MAP(PrerenderDispatcher, message) |
75 IPC_MESSAGE_HANDLER(PrerenderMsg_OnPrerenderStart, OnPrerenderStart) | 87 IPC_MESSAGE_HANDLER(PrerenderMsg_OnPrerenderStart, OnPrerenderStart) |
76 IPC_MESSAGE_HANDLER(PrerenderMsg_OnPrerenderAddAlias, OnPrerenderAddAlias) | 88 IPC_MESSAGE_HANDLER(PrerenderMsg_OnPrerenderAddAlias, OnPrerenderAddAlias) |
77 IPC_MESSAGE_HANDLER(PrerenderMsg_OnPrerenderStop, OnPrerenderStop) | 89 IPC_MESSAGE_HANDLER(PrerenderMsg_OnPrerenderStop, OnPrerenderStop) |
78 IPC_MESSAGE_UNHANDLED(handled = false) | 90 IPC_MESSAGE_UNHANDLED(handled = false) |
79 IPC_END_MESSAGE_MAP() | 91 IPC_END_MESSAGE_MAP() |
80 | 92 |
81 return handled; | 93 return handled; |
82 } | 94 } |
83 | 95 |
84 void PrerenderDispatcher::add(const WebKit::WebPrerender& prerender) { | 96 void PrerenderDispatcher::add(const WebPrerender& prerender) { |
85 const PrerenderExtraData& extra_data = | 97 const PrerenderExtraData& extra_data = |
86 PrerenderExtraData::FromPrerender(prerender); | 98 PrerenderExtraData::FromPrerender(prerender); |
87 prerenders_[extra_data.prerender_id()] = prerender.url(); | 99 prerenders_[extra_data.prerender_id()] = prerender; |
88 | 100 |
89 content::RenderThread::Get()->Send(new PrerenderHostMsg_AddLinkRelPrerender( | 101 content::RenderThread::Get()->Send(new PrerenderHostMsg_AddLinkRelPrerender( |
90 extra_data.prerender_id(), GURL(prerender.url()), | 102 extra_data.prerender_id(), GURL(prerender.url()), |
91 content::Referrer(GURL(prerender.referrer()), prerender.referrerPolicy()), | 103 content::Referrer(GURL(prerender.referrer()), |
104 prerender.referrerPolicy()), | |
92 extra_data.size(), extra_data.render_view_route_id())); | 105 extra_data.size(), extra_data.render_view_route_id())); |
93 } | 106 } |
94 | 107 |
95 void PrerenderDispatcher::cancel(const WebKit::WebPrerender& prerender) { | 108 void PrerenderDispatcher::cancel(const WebPrerender& prerender) { |
96 const PrerenderExtraData& extra_data = | 109 const PrerenderExtraData& extra_data = |
97 PrerenderExtraData::FromPrerender(prerender); | 110 PrerenderExtraData::FromPrerender(prerender); |
98 content::RenderThread::Get()->Send( | 111 content::RenderThread::Get()->Send( |
99 new PrerenderHostMsg_CancelLinkRelPrerender(extra_data.prerender_id())); | 112 new PrerenderHostMsg_CancelLinkRelPrerender(extra_data.prerender_id())); |
100 } | 113 } |
101 | 114 |
102 void PrerenderDispatcher::abandon(const WebKit::WebPrerender& prerender) { | 115 void PrerenderDispatcher::abandon(const WebPrerender& prerender) { |
103 const PrerenderExtraData& extra_data = | 116 const PrerenderExtraData& extra_data = |
104 PrerenderExtraData::FromPrerender(prerender); | 117 PrerenderExtraData::FromPrerender(prerender); |
105 content::RenderThread::Get()->Send( | 118 content::RenderThread::Get()->Send( |
106 new PrerenderHostMsg_AbandonLinkRelPrerender(extra_data.prerender_id())); | 119 new PrerenderHostMsg_AbandonLinkRelPrerender(extra_data.prerender_id())); |
107 } | 120 } |
108 | 121 |
109 } // namespace prerender | 122 } // namespace prerender |
OLD | NEW |