OLD | NEW |
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 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_manager.h" | 5 #include "chrome/browser/prerender/prerender_manager.h" |
6 | 6 |
7 #include "base/logging.h" | 7 #include "base/logging.h" |
| 8 #include "base/metrics/histogram.h" |
8 #include "base/time.h" | 9 #include "base/time.h" |
9 #include "base/utf_string_conversions.h" | 10 #include "base/utf_string_conversions.h" |
10 #include "chrome/browser/prerender/prerender_contents.h" | 11 #include "chrome/browser/prerender/prerender_contents.h" |
11 #include "chrome/browser/renderer_host/render_view_host.h" | 12 #include "chrome/browser/renderer_host/render_view_host.h" |
12 #include "chrome/browser/tab_contents/tab_contents.h" | 13 #include "chrome/browser/tab_contents/tab_contents.h" |
13 #include "chrome/browser/tab_contents/render_view_host_manager.h" | 14 #include "chrome/browser/tab_contents/render_view_host_manager.h" |
14 #include "chrome/common/render_messages.h" | 15 #include "chrome/common/render_messages.h" |
15 | 16 |
16 struct PrerenderManager::PrerenderContentsData { | 17 struct PrerenderManager::PrerenderContentsData { |
17 PrerenderContents* contents_; | 18 PrerenderContents* contents_; |
18 base::Time start_time_; | 19 base::Time start_time_; |
19 GURL url_; | 20 GURL url_; |
20 PrerenderContentsData(PrerenderContents* contents, | 21 PrerenderContentsData(PrerenderContents* contents, |
21 base::Time start_time, | 22 base::Time start_time, |
22 GURL url) | 23 GURL url) |
23 : contents_(contents), | 24 : contents_(contents), |
24 start_time_(start_time), | 25 start_time_(start_time), |
25 url_(url) { | 26 url_(url) { |
26 } | 27 } |
27 }; | 28 }; |
28 | 29 |
29 PrerenderManager::PrerenderManager(Profile* profile) | 30 PrerenderManager::PrerenderManager(Profile* profile) |
30 : profile_(profile), | 31 : profile_(profile), |
31 max_prerender_age_(base::TimeDelta::FromSeconds( | 32 max_prerender_age_(base::TimeDelta::FromSeconds( |
32 kDefaultMaxPrerenderAgeSeconds)), | 33 kDefaultMaxPrerenderAgeSeconds)), |
33 max_elements_(kDefaultMaxPrerenderElements) { | 34 max_elements_(kDefaultMaxPrerenderElements), |
| 35 mode_(PRERENDER_MODE_ENABLED) { |
34 } | 36 } |
35 | 37 |
36 PrerenderManager::~PrerenderManager() { | 38 PrerenderManager::~PrerenderManager() { |
37 while (prerender_list_.size() > 0) { | 39 while (prerender_list_.size() > 0) { |
38 PrerenderContentsData data = prerender_list_.front(); | 40 PrerenderContentsData data = prerender_list_.front(); |
39 prerender_list_.pop_front(); | 41 prerender_list_.pop_front(); |
40 delete data.contents_; | 42 delete data.contents_; |
41 } | 43 } |
42 } | 44 } |
43 | 45 |
(...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
101 tc->SwapInRenderViewHost(rvh); | 103 tc->SwapInRenderViewHost(rvh); |
102 | 104 |
103 ViewHostMsg_FrameNavigate_Params* p = pc->navigate_params(); | 105 ViewHostMsg_FrameNavigate_Params* p = pc->navigate_params(); |
104 if (p != NULL) | 106 if (p != NULL) |
105 tc->DidNavigate(rvh, *p); | 107 tc->DidNavigate(rvh, *p); |
106 | 108 |
107 string16 title = pc->title(); | 109 string16 title = pc->title(); |
108 if (!title.empty()) | 110 if (!title.empty()) |
109 tc->UpdateTitle(rvh, pc->page_id(), UTF16ToWideHack(title)); | 111 tc->UpdateTitle(rvh, pc->page_id(), UTF16ToWideHack(title)); |
110 | 112 |
| 113 if (pc->has_stopped_loading()) |
| 114 tc->DidStopLoading(); |
| 115 |
111 return true; | 116 return true; |
112 } | 117 } |
113 | 118 |
114 void PrerenderManager::RemoveEntry(PrerenderContents* entry) { | 119 void PrerenderManager::RemoveEntry(PrerenderContents* entry) { |
115 DCHECK(CalledOnValidThread()); | 120 DCHECK(CalledOnValidThread()); |
116 for (std::list<PrerenderContentsData>::iterator it = prerender_list_.begin(); | 121 for (std::list<PrerenderContentsData>::iterator it = prerender_list_.begin(); |
117 it != prerender_list_.end(); | 122 it != prerender_list_.end(); |
118 ++it) { | 123 ++it) { |
119 if (it->contents_ == entry) { | 124 if (it->contents_ == entry) { |
120 prerender_list_.erase(it); | 125 prerender_list_.erase(it); |
(...skipping 11 matching lines...) Expand all Loading... |
132 bool PrerenderManager::IsPrerenderElementFresh(const base::Time start) const { | 137 bool PrerenderManager::IsPrerenderElementFresh(const base::Time start) const { |
133 base::Time now = GetCurrentTime(); | 138 base::Time now = GetCurrentTime(); |
134 return (now - start < max_prerender_age_); | 139 return (now - start < max_prerender_age_); |
135 } | 140 } |
136 | 141 |
137 PrerenderContents* PrerenderManager::CreatePrerenderContents( | 142 PrerenderContents* PrerenderManager::CreatePrerenderContents( |
138 const GURL& url, | 143 const GURL& url, |
139 const std::vector<GURL>& alias_urls) { | 144 const std::vector<GURL>& alias_urls) { |
140 return new PrerenderContents(this, profile_, url, alias_urls); | 145 return new PrerenderContents(this, profile_, url, alias_urls); |
141 } | 146 } |
| 147 |
| 148 void PrerenderManager::RecordPerceivedPageLoadTime(base::TimeDelta pplt) { |
| 149 switch(mode_) { |
| 150 case PRERENDER_MODE_EXPERIMENT_CONTROL_GROUP: |
| 151 UMA_HISTOGRAM_TIMES("PLT.PerceivedPageLoadTime_PrerenderControl", pplt); |
| 152 break; |
| 153 case PRERENDER_MODE_EXPERIMENT_PRERENDER_GROUP: |
| 154 UMA_HISTOGRAM_TIMES("PLT.PerceivedPageLoadTime_PrerenderTreatment", pplt); |
| 155 break; |
| 156 default: |
| 157 break; |
| 158 } |
| 159 } |
OLD | NEW |