diff options
author | eroman@chromium.org <eroman@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-11-06 08:58:16 +0000 |
---|---|---|
committer | eroman@chromium.org <eroman@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-11-06 08:58:16 +0000 |
commit | 3d04ea5e909d831ddc40c1e8d89b21f80cbd353c (patch) | |
tree | 23ffc3eb4eac8ff73eab2dde50caea7dc947a329 | |
parent | 8de85a60ef3c615360d0c644f7f16f9a13103865 (diff) | |
download | chromium_src-3d04ea5e909d831ddc40c1e8d89b21f80cbd353c.zip chromium_src-3d04ea5e909d831ddc40c1e8d89b21f80cbd353c.tar.gz chromium_src-3d04ea5e909d831ddc40c1e8d89b21f80cbd353c.tar.bz2 |
Remove an access to Profile from the IO thread.
Also explicitly hold a reference to the URLRequestContextGetter as long as the task is outstanding on the IO thread.
BUG=26893
Review URL: http://codereview.chromium.org/371016
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@31215 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | chrome/browser/browsing_data_remover.cc | 24 | ||||
-rw-r--r-- | chrome/browser/browsing_data_remover.h | 3 |
2 files changed, 22 insertions, 5 deletions
diff --git a/chrome/browser/browsing_data_remover.cc b/chrome/browser/browsing_data_remover.cc index 6db8543..0a646fa 100644 --- a/chrome/browser/browsing_data_remover.cc +++ b/chrome/browser/browsing_data_remover.cc @@ -134,12 +134,23 @@ void BrowsingDataRemover::Remove(int remove_mask) { // Invoke ClearBrowsingDataView::ClearCache on the IO thread. waiting_for_clear_cache_ = true; UserMetrics::RecordAction(L"ClearBrowsingData_Cache", profile_); + + URLRequestContextGetter* main_context_getter = + profile_->GetRequestContext(); + URLRequestContextGetter* media_context_getter = + profile_->GetRequestContextForMedia(); + + // Balanced in ClearCacheOnIOThread(). + main_context_getter->AddRef(); + media_context_getter->AddRef(); + ChromeThread::PostTask( ChromeThread::IO, FROM_HERE, NewRunnableMethod( this, &BrowsingDataRemover::ClearCacheOnIOThread, - profile_->GetRequestContext(), + main_context_getter, + media_context_getter, delete_begin_, delete_end_)); } @@ -219,7 +230,8 @@ void BrowsingDataRemover::ClearedCache() { } void BrowsingDataRemover::ClearCacheOnIOThread( - URLRequestContextGetter* context_getter, + URLRequestContextGetter* main_context_getter, + URLRequestContextGetter* media_context_getter, base::Time delete_begin, base::Time delete_end) { // This function should be called on the IO thread. @@ -227,7 +239,7 @@ void BrowsingDataRemover::ClearCacheOnIOThread( // Get a pointer to the cache. net::HttpTransactionFactory* factory = - context_getter->GetURLRequestContext()->http_transaction_factory(); + main_context_getter->GetURLRequestContext()->http_transaction_factory(); disk_cache::Backend* cache = factory->GetCache()->disk_cache(); // |cache| can be null since it is lazily initialized, in this case we do @@ -240,7 +252,7 @@ void BrowsingDataRemover::ClearCacheOnIOThread( } // Get a pointer to the media cache. - factory = profile_->GetRequestContextForMedia()->GetURLRequestContext()-> + factory = media_context_getter->GetURLRequestContext()-> http_transaction_factory(); cache = factory->GetCache()->disk_cache(); @@ -253,6 +265,10 @@ void BrowsingDataRemover::ClearCacheOnIOThread( cache->DoomEntriesBetween(delete_begin, delete_end); } + // Balance the AddRef()s done on the UI thread by Remove(). + main_context_getter->Release(); + media_context_getter->Release(); + // Notify the UI thread that we are done. ChromeThread::PostTask( ChromeThread::UI, FROM_HERE, diff --git a/chrome/browser/browsing_data_remover.h b/chrome/browser/browsing_data_remover.h index 73d5e74..320c7d3 100644 --- a/chrome/browser/browsing_data_remover.h +++ b/chrome/browser/browsing_data_remover.h @@ -86,7 +86,8 @@ class BrowsingDataRemover : public NotificationObserver { void ClearedCache(); // Invoked on the IO thread to delete from the cache. - void ClearCacheOnIOThread(URLRequestContextGetter* context_getter, + void ClearCacheOnIOThread(URLRequestContextGetter* main_context_getter, + URLRequestContextGetter* media_context_getter, base::Time delete_begin, base::Time delete_end); |