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/browser/prerender/prerender_manager.h" | 5 #include "chrome/browser/prerender/prerender_manager.h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 | 8 |
9 #include <algorithm> | 9 #include <algorithm> |
10 #include <functional> | 10 #include <functional> |
(...skipping 139 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
150 time(time) { | 150 time(time) { |
151 } | 151 } |
152 | 152 |
153 GURL url; | 153 GURL url; |
154 base::TimeTicks time; | 154 base::TimeTicks time; |
155 }; | 155 }; |
156 | 156 |
157 PrerenderManager::PrerenderManager(Profile* profile) | 157 PrerenderManager::PrerenderManager(Profile* profile) |
158 : profile_(profile), | 158 : profile_(profile), |
159 prerender_contents_factory_(PrerenderContents::CreateFactory()), | 159 prerender_contents_factory_(PrerenderContents::CreateFactory()), |
160 last_prerender_start_time_(GetCurrentTimeTicks() - | 160 last_prerender_start_time_( |
| 161 GetCurrentTimeTicks() - |
161 base::TimeDelta::FromMilliseconds(kMinTimeBetweenPrerendersMs)), | 162 base::TimeDelta::FromMilliseconds(kMinTimeBetweenPrerendersMs)), |
162 prerender_history_(new PrerenderHistory(kHistoryLength)), | 163 prerender_history_(new PrerenderHistory(kHistoryLength)), |
163 histograms_(new PrerenderHistograms()), | 164 histograms_(new PrerenderHistograms()), |
164 profile_network_bytes_(0), | 165 profile_network_bytes_(0), |
165 last_recorded_profile_network_bytes_(0) { | 166 last_recorded_profile_network_bytes_(0), |
| 167 weak_factory_(this) { |
166 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 168 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
167 | 169 |
168 // Certain experiments override our default config_ values. | 170 // Certain experiments override our default config_ values. |
169 switch (PrerenderManager::GetMode()) { | 171 switch (PrerenderManager::GetMode()) { |
170 case PrerenderManager::PRERENDER_MODE_EXPERIMENT_MULTI_PRERENDER_GROUP: | 172 case PrerenderManager::PRERENDER_MODE_EXPERIMENT_MULTI_PRERENDER_GROUP: |
171 config_.max_link_concurrency = 4; | 173 config_.max_link_concurrency = 4; |
172 config_.max_link_concurrency_per_launcher = 2; | 174 config_.max_link_concurrency_per_launcher = 2; |
173 break; | 175 break; |
174 case PrerenderManager::PRERENDER_MODE_EXPERIMENT_15MIN_TTL_GROUP: | 176 case PrerenderManager::PRERENDER_MODE_EXPERIMENT_15MIN_TTL_GROUP: |
175 config_.time_to_live = base::TimeDelta::FromMinutes(15); | 177 config_.time_to_live = base::TimeDelta::FromMinutes(15); |
(...skipping 849 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1025 to_delete_prerenders_.clear(); | 1027 to_delete_prerenders_.clear(); |
1026 | 1028 |
1027 // Measure how long a the various cleanup tasks took. http://crbug.com/305419. | 1029 // Measure how long a the various cleanup tasks took. http://crbug.com/305419. |
1028 UMA_HISTOGRAM_TIMES("Prerender.PeriodicCleanupDeleteContentsTime", | 1030 UMA_HISTOGRAM_TIMES("Prerender.PeriodicCleanupDeleteContentsTime", |
1029 cleanup_timer.Elapsed()); | 1031 cleanup_timer.Elapsed()); |
1030 } | 1032 } |
1031 | 1033 |
1032 void PrerenderManager::PostCleanupTask() { | 1034 void PrerenderManager::PostCleanupTask() { |
1033 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 1035 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
1034 base::ThreadTaskRunnerHandle::Get()->PostTask( | 1036 base::ThreadTaskRunnerHandle::Get()->PostTask( |
1035 FROM_HERE, base::Bind(&PrerenderManager::PeriodicCleanup, AsWeakPtr())); | 1037 FROM_HERE, base::Bind(&PrerenderManager::PeriodicCleanup, |
| 1038 weak_factory_.GetWeakPtr())); |
1036 } | 1039 } |
1037 | 1040 |
1038 base::TimeTicks PrerenderManager::GetExpiryTimeForNewPrerender( | 1041 base::TimeTicks PrerenderManager::GetExpiryTimeForNewPrerender( |
1039 Origin origin) const { | 1042 Origin origin) const { |
1040 return GetCurrentTimeTicks() + config_.time_to_live; | 1043 return GetCurrentTimeTicks() + config_.time_to_live; |
1041 } | 1044 } |
1042 | 1045 |
1043 base::TimeTicks PrerenderManager::GetExpiryTimeForNavigatedAwayPrerender() | 1046 base::TimeTicks PrerenderManager::GetExpiryTimeForNavigatedAwayPrerender() |
1044 const { | 1047 const { |
1045 return GetCurrentTimeTicks() + config_.abandon_time_to_live; | 1048 return GetCurrentTimeTicks() + config_.abandon_time_to_live; |
(...skipping 284 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1330 DCHECK_EQ(1u, erased); | 1333 DCHECK_EQ(1u, erased); |
1331 } | 1334 } |
1332 | 1335 |
1333 void PrerenderManager::SetPrerenderContentsFactoryForTest( | 1336 void PrerenderManager::SetPrerenderContentsFactoryForTest( |
1334 PrerenderContents::Factory* prerender_contents_factory) { | 1337 PrerenderContents::Factory* prerender_contents_factory) { |
1335 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 1338 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
1336 prerender_contents_factory_.reset(prerender_contents_factory); | 1339 prerender_contents_factory_.reset(prerender_contents_factory); |
1337 } | 1340 } |
1338 | 1341 |
1339 } // namespace prerender | 1342 } // namespace prerender |
OLD | NEW |