| 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 <string> | 7 #include <string> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/bind_helpers.h" | 10 #include "base/bind_helpers.h" |
| (...skipping 397 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 408 | 408 |
| 409 // Try to set the prerendered page as used, so any subsequent attempts to | 409 // Try to set the prerendered page as used, so any subsequent attempts to |
| 410 // cancel on other threads will fail. If this fails because the prerender | 410 // cancel on other threads will fail. If this fails because the prerender |
| 411 // was already cancelled, possibly on another thread, fail. | 411 // was already cancelled, possibly on another thread, fail. |
| 412 if (!prerender_tracker_->TryUse(child_id, route_id)) | 412 if (!prerender_tracker_->TryUse(child_id, route_id)) |
| 413 return false; | 413 return false; |
| 414 | 414 |
| 415 if (!prerender_contents->load_start_time().is_null()) { | 415 if (!prerender_contents->load_start_time().is_null()) { |
| 416 histograms_->RecordTimeUntilUsed(GetCurrentTimeTicks() - | 416 histograms_->RecordTimeUntilUsed(GetCurrentTimeTicks() - |
| 417 prerender_contents->load_start_time(), | 417 prerender_contents->load_start_time(), |
| 418 config_.max_age); | 418 GetMaxAge()); |
| 419 } | 419 } |
| 420 | 420 |
| 421 histograms_->RecordPerSessionCount(++prerenders_per_session_count_); | 421 histograms_->RecordPerSessionCount(++prerenders_per_session_count_); |
| 422 histograms_->RecordUsedPrerender(prerender_contents->origin()); | 422 histograms_->RecordUsedPrerender(prerender_contents->origin()); |
| 423 prerender_contents->set_final_status(FINAL_STATUS_USED); | 423 prerender_contents->set_final_status(FINAL_STATUS_USED); |
| 424 | 424 |
| 425 new_render_view_host->Send( | 425 new_render_view_host->Send( |
| 426 new ChromeViewMsg_SetIsPrerendering(new_render_view_host->routing_id(), | 426 new ChromeViewMsg_SetIsPrerendering(new_render_view_host->routing_id(), |
| 427 false)); | 427 false)); |
| 428 | 428 |
| (...skipping 292 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 721 DictionaryValue* dict_value = new DictionaryValue(); | 721 DictionaryValue* dict_value = new DictionaryValue(); |
| 722 dict_value->Set("history", prerender_history_->GetEntriesAsValue()); | 722 dict_value->Set("history", prerender_history_->GetEntriesAsValue()); |
| 723 dict_value->Set("active", GetActivePrerendersAsValue()); | 723 dict_value->Set("active", GetActivePrerendersAsValue()); |
| 724 dict_value->SetBoolean("enabled", enabled_); | 724 dict_value->SetBoolean("enabled", enabled_); |
| 725 dict_value->SetBoolean("omnibox_enabled", IsOmniboxEnabled(profile_)); | 725 dict_value->SetBoolean("omnibox_enabled", IsOmniboxEnabled(profile_)); |
| 726 // If prerender is disabled via a flag this method is not even called. | 726 // If prerender is disabled via a flag this method is not even called. |
| 727 if (IsControlGroup()) | 727 if (IsControlGroup()) |
| 728 dict_value->SetString("disabled_reason", "(Disabled for testing)"); | 728 dict_value->SetString("disabled_reason", "(Disabled for testing)"); |
| 729 if (IsNoUseGroup()) | 729 if (IsNoUseGroup()) |
| 730 dict_value->SetString("disabled_reason", "(Not using prerendered pages)"); | 730 dict_value->SetString("disabled_reason", "(Not using prerendered pages)"); |
| 731 if (GetMode() == PRERENDER_MODE_EXPERIMENT_LONG_TTL_GROUP) |
| 732 dict_value->SetString("disabled_reason", "(Long TTL)"); |
| 731 return dict_value; | 733 return dict_value; |
| 732 } | 734 } |
| 733 | 735 |
| 734 void PrerenderManager::ClearData(int clear_flags) { | 736 void PrerenderManager::ClearData(int clear_flags) { |
| 735 DCHECK_GE(clear_flags, 0); | 737 DCHECK_GE(clear_flags, 0); |
| 736 DCHECK_LT(clear_flags, CLEAR_MAX); | 738 DCHECK_LT(clear_flags, CLEAR_MAX); |
| 737 if (clear_flags & CLEAR_PRERENDER_CONTENTS) | 739 if (clear_flags & CLEAR_PRERENDER_CONTENTS) |
| 738 DestroyAllContents(FINAL_STATUS_CACHE_OR_HISTORY_CLEARED); | 740 DestroyAllContents(FINAL_STATUS_CACHE_OR_HISTORY_CLEARED); |
| 739 // This has to be second, since destroying prerenders can add to the history. | 741 // This has to be second, since destroying prerenders can add to the history. |
| 740 if (clear_flags & CLEAR_PRERENDER_HISTORY) | 742 if (clear_flags & CLEAR_PRERENDER_HISTORY) |
| (...skipping 236 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 977 } | 979 } |
| 978 | 980 |
| 979 void PrerenderManager::PostCleanupTask() { | 981 void PrerenderManager::PostCleanupTask() { |
| 980 DCHECK(CalledOnValidThread()); | 982 DCHECK(CalledOnValidThread()); |
| 981 MessageLoop::current()->PostTask( | 983 MessageLoop::current()->PostTask( |
| 982 FROM_HERE, | 984 FROM_HERE, |
| 983 base::Bind(&PrerenderManager::PeriodicCleanup, | 985 base::Bind(&PrerenderManager::PeriodicCleanup, |
| 984 weak_factory_.GetWeakPtr())); | 986 weak_factory_.GetWeakPtr())); |
| 985 } | 987 } |
| 986 | 988 |
| 989 base::TimeDelta PrerenderManager::GetMaxAge() const { |
| 990 base::TimeDelta max_age = config_.max_age; |
| 991 if (GetMode() == PRERENDER_MODE_EXPERIMENT_LONG_TTL_GROUP) |
| 992 max_age *= 10; |
| 993 return max_age; |
| 994 } |
| 995 |
| 987 bool PrerenderManager::IsPrerenderElementFresh(const base::Time start) const { | 996 bool PrerenderManager::IsPrerenderElementFresh(const base::Time start) const { |
| 988 DCHECK(CalledOnValidThread()); | 997 DCHECK(CalledOnValidThread()); |
| 989 base::Time now = GetCurrentTime(); | 998 base::Time now = GetCurrentTime(); |
| 990 return (now - start < config_.max_age); | 999 return (now - start < GetMaxAge()); |
| 991 } | 1000 } |
| 992 | 1001 |
| 993 void PrerenderManager::DeleteOldEntries() { | 1002 void PrerenderManager::DeleteOldEntries() { |
| 994 DCHECK(CalledOnValidThread()); | 1003 DCHECK(CalledOnValidThread()); |
| 995 while (!prerender_list_.empty()) { | 1004 while (!prerender_list_.empty()) { |
| 996 PrerenderContentsData data = prerender_list_.front(); | 1005 PrerenderContentsData data = prerender_list_.front(); |
| 997 if (IsPrerenderElementFresh(data.start_time_)) | 1006 if (IsPrerenderElementFresh(data.start_time_)) |
| 998 return; | 1007 return; |
| 999 data.contents_->Destroy(FINAL_STATUS_TIMED_OUT); | 1008 data.contents_->Destroy(FINAL_STATUS_TIMED_OUT); |
| 1000 } | 1009 } |
| (...skipping 193 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1194 if (!render_process_host || !render_process_host->GetBrowserContext()) | 1203 if (!render_process_host || !render_process_host->GetBrowserContext()) |
| 1195 return NULL; | 1204 return NULL; |
| 1196 Profile* profile = Profile::FromBrowserContext( | 1205 Profile* profile = Profile::FromBrowserContext( |
| 1197 render_process_host->GetBrowserContext()); | 1206 render_process_host->GetBrowserContext()); |
| 1198 if (!profile) | 1207 if (!profile) |
| 1199 return NULL; | 1208 return NULL; |
| 1200 return PrerenderManagerFactory::GetInstance()->GetForProfile(profile); | 1209 return PrerenderManagerFactory::GetInstance()->GetForProfile(profile); |
| 1201 } | 1210 } |
| 1202 | 1211 |
| 1203 } // namespace prerender | 1212 } // namespace prerender |
| OLD | NEW |