Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(159)

Side by Side Diff: chrome/browser/prerender/prerender_manager.cc

Issue 14113053: chrome: Use base::MessageLoop. (Part 3) (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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 <algorithm> 7 #include <algorithm>
8 #include <functional> 8 #include <functional>
9 #include <string> 9 #include <string>
10 #include <vector> 10 #include <vector>
(...skipping 138 matching lines...) Expand 10 before | Expand all | Expand 10 after
149 class PrerenderManager::OnCloseWebContentsDeleter 149 class PrerenderManager::OnCloseWebContentsDeleter
150 : public content::WebContentsDelegate, 150 : public content::WebContentsDelegate,
151 public base::SupportsWeakPtr< 151 public base::SupportsWeakPtr<
152 PrerenderManager::OnCloseWebContentsDeleter> { 152 PrerenderManager::OnCloseWebContentsDeleter> {
153 public: 153 public:
154 OnCloseWebContentsDeleter(PrerenderManager* manager, 154 OnCloseWebContentsDeleter(PrerenderManager* manager,
155 WebContents* tab) 155 WebContents* tab)
156 : manager_(manager), 156 : manager_(manager),
157 tab_(tab) { 157 tab_(tab) {
158 tab_->SetDelegate(this); 158 tab_->SetDelegate(this);
159 MessageLoop::current()->PostDelayedTask(FROM_HERE, 159 base::MessageLoop::current()->PostDelayedTask(
160 FROM_HERE,
160 base::Bind(&OnCloseWebContentsDeleter::ScheduleWebContentsForDeletion, 161 base::Bind(&OnCloseWebContentsDeleter::ScheduleWebContentsForDeletion,
161 AsWeakPtr(), true), 162 AsWeakPtr(),
163 true),
162 base::TimeDelta::FromSeconds(kDeleteWithExtremePrejudiceSeconds)); 164 base::TimeDelta::FromSeconds(kDeleteWithExtremePrejudiceSeconds));
163 } 165 }
164 166
165 virtual void CloseContents(WebContents* source) OVERRIDE { 167 virtual void CloseContents(WebContents* source) OVERRIDE {
166 DCHECK_EQ(tab_, source); 168 DCHECK_EQ(tab_, source);
167 ScheduleWebContentsForDeletion(false); 169 ScheduleWebContentsForDeletion(false);
168 } 170 }
169 171
170 virtual void SwappedOut(WebContents* source) OVERRIDE { 172 virtual void SwappedOut(WebContents* source) OVERRIDE {
171 DCHECK_EQ(tab_, source); 173 DCHECK_EQ(tab_, source);
(...skipping 1000 matching lines...) Expand 10 before | Expand all | Expand 10 after
1172 // And now check for prerenders using too much memory. 1174 // And now check for prerenders using too much memory.
1173 std::for_each(prerender_contents.begin(), prerender_contents.end(), 1175 std::for_each(prerender_contents.begin(), prerender_contents.end(),
1174 std::mem_fun( 1176 std::mem_fun(
1175 &PrerenderContents::DestroyWhenUsingTooManyResources)); 1177 &PrerenderContents::DestroyWhenUsingTooManyResources));
1176 1178
1177 to_delete_prerenders_.clear(); 1179 to_delete_prerenders_.clear();
1178 } 1180 }
1179 1181
1180 void PrerenderManager::PostCleanupTask() { 1182 void PrerenderManager::PostCleanupTask() {
1181 DCHECK(CalledOnValidThread()); 1183 DCHECK(CalledOnValidThread());
1182 MessageLoop::current()->PostTask( 1184 base::MessageLoop::current()->PostTask(
1183 FROM_HERE, 1185 FROM_HERE, base::Bind(&PrerenderManager::PeriodicCleanup, AsWeakPtr()));
1184 base::Bind(&PrerenderManager::PeriodicCleanup, AsWeakPtr()));
1185 } 1186 }
1186 1187
1187 base::TimeTicks PrerenderManager::GetExpiryTimeForNewPrerender() const { 1188 base::TimeTicks PrerenderManager::GetExpiryTimeForNewPrerender() const {
1188 return GetCurrentTimeTicks() + config_.time_to_live; 1189 return GetCurrentTimeTicks() + config_.time_to_live;
1189 } 1190 }
1190 1191
1191 base::TimeTicks PrerenderManager::GetExpiryTimeForNavigatedAwayPrerender() 1192 base::TimeTicks PrerenderManager::GetExpiryTimeForNavigatedAwayPrerender()
1192 const { 1193 const {
1193 return GetCurrentTimeTicks() + config_.abandon_time_to_live; 1194 return GetCurrentTimeTicks() + config_.abandon_time_to_live;
1194 } 1195 }
(...skipping 312 matching lines...) Expand 10 before | Expand all | Expand 10 after
1507 logged_in_state_->erase(domain_key); 1508 logged_in_state_->erase(domain_key);
1508 } 1509 }
1509 1510
1510 void PrerenderManager::LoggedInPredictorDataReceived( 1511 void PrerenderManager::LoggedInPredictorDataReceived(
1511 scoped_ptr<LoggedInStateMap> new_map) { 1512 scoped_ptr<LoggedInStateMap> new_map) {
1512 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 1513 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
1513 logged_in_state_.swap(new_map); 1514 logged_in_state_.swap(new_map);
1514 } 1515 }
1515 1516
1516 } // namespace prerender 1517 } // namespace prerender
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698