Chromium Code Reviews| 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/browsing_data/browsing_data_appcache_helper.h" | 5 #include "chrome/browser/browsing_data/browsing_data_appcache_helper.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/bind_helpers.h" | 8 #include "base/bind_helpers.h" |
| 9 #include "chrome/browser/browsing_data/browsing_data_helper.h" | 9 #include "chrome/browser/browsing_data/browsing_data_helper.h" |
| 10 #include "chrome/browser/profiles/profile.h" | |
| 11 #include "chrome/common/url_constants.h" | |
| 12 #include "content/public/browser/browser_context.h" | 10 #include "content/public/browser/browser_context.h" |
| 13 #include "content/public/browser/browser_thread.h" | 11 #include "content/public/browser/browser_thread.h" |
| 14 #include "content/public/browser/storage_partition.h" | 12 #include "content/public/browser/storage_partition.h" |
| 15 | 13 |
| 14 using content::BrowserContext; | |
| 16 using content::BrowserThread; | 15 using content::BrowserThread; |
| 17 using content::BrowserContext; | |
| 18 | 16 |
| 19 BrowsingDataAppCacheHelper::BrowsingDataAppCacheHelper(Profile* profile) | 17 BrowsingDataAppCacheHelper::BrowsingDataAppCacheHelper( |
| 18 BrowserContext* browser_context) | |
| 20 : is_fetching_(false), | 19 : is_fetching_(false), |
| 21 appcache_service_(BrowserContext::GetDefaultStoragePartition(profile)-> | 20 appcache_service_(BrowserContext::GetDefaultStoragePartition( |
| 22 GetAppCacheService()) { | 21 browser_context)->GetAppCacheService()) { |
| 23 } | 22 } |
| 24 | 23 |
| 25 void BrowsingDataAppCacheHelper::StartFetching(const base::Closure& callback) { | 24 void BrowsingDataAppCacheHelper::StartFetching(const base::Closure& callback) { |
| 26 if (BrowserThread::CurrentlyOn(BrowserThread::UI)) { | 25 if (BrowserThread::CurrentlyOn(BrowserThread::UI)) { |
| 27 DCHECK(!is_fetching_); | 26 DCHECK(!is_fetching_); |
| 28 DCHECK(!callback.is_null()); | 27 DCHECK(!callback.is_null()); |
| 29 is_fetching_ = true; | 28 is_fetching_ = true; |
| 30 info_collection_ = new content::AppCacheInfoCollection; | 29 info_collection_ = new content::AppCacheInfoCollection; |
| 31 completion_callback_ = callback; | 30 completion_callback_ = callback; |
| 32 BrowserThread::PostTask( | 31 BrowserThread::PostTask( |
| 33 BrowserThread::IO, FROM_HERE, | 32 BrowserThread::IO, FROM_HERE, |
| 34 base::Bind(&BrowsingDataAppCacheHelper::StartFetching, this, callback)); | 33 base::Bind(&BrowsingDataAppCacheHelper::StartFetching, this, callback)); |
| 35 return; | 34 return; |
| 36 } | 35 } |
| 37 | 36 |
| 38 DCHECK_CURRENTLY_ON(BrowserThread::IO); | 37 DCHECK_CURRENTLY_ON(BrowserThread::IO); |
| 39 appcache_info_callback_.Reset( | 38 appcache_service_->GetAllAppCacheInfo( |
|
Bernhard Bauer
2014/09/05 16:15:12
So, what happens when this object is destroyed now
vabr (Chromium)
2014/09/19 12:35:47
Thanks for catching this. I was confused when firs
| |
| 39 info_collection_.get(), | |
| 40 base::Bind(&BrowsingDataAppCacheHelper::OnFetchComplete, | 40 base::Bind(&BrowsingDataAppCacheHelper::OnFetchComplete, |
| 41 base::Unretained(this))); | 41 base::Unretained(this))); |
| 42 appcache_service_->GetAllAppCacheInfo(info_collection_.get(), | |
| 43 appcache_info_callback_.callback()); | |
| 44 } | 42 } |
| 45 | 43 |
| 46 void BrowsingDataAppCacheHelper::DeleteAppCacheGroup( | 44 void BrowsingDataAppCacheHelper::DeleteAppCacheGroup( |
| 47 const GURL& manifest_url) { | 45 const GURL& manifest_url) { |
| 48 if (BrowserThread::CurrentlyOn(BrowserThread::UI)) { | 46 if (BrowserThread::CurrentlyOn(BrowserThread::UI)) { |
| 49 BrowserThread::PostTask( | 47 BrowserThread::PostTask( |
| 50 BrowserThread::IO, FROM_HERE, | 48 BrowserThread::IO, FROM_HERE, |
| 51 base::Bind(&BrowsingDataAppCacheHelper::DeleteAppCacheGroup, this, | 49 base::Bind(&BrowsingDataAppCacheHelper::DeleteAppCacheGroup, this, |
| 52 manifest_url)); | 50 manifest_url)); |
| 53 return; | 51 return; |
| (...skipping 26 matching lines...) Expand all Loading... | |
| 80 } | 78 } |
| 81 | 79 |
| 82 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 80 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 83 DCHECK(is_fetching_); | 81 DCHECK(is_fetching_); |
| 84 is_fetching_ = false; | 82 is_fetching_ = false; |
| 85 completion_callback_.Run(); | 83 completion_callback_.Run(); |
| 86 completion_callback_.Reset(); | 84 completion_callback_.Reset(); |
| 87 } | 85 } |
| 88 | 86 |
| 89 CannedBrowsingDataAppCacheHelper::CannedBrowsingDataAppCacheHelper( | 87 CannedBrowsingDataAppCacheHelper::CannedBrowsingDataAppCacheHelper( |
| 90 Profile* profile) | 88 BrowserContext* browser_context) |
| 91 : BrowsingDataAppCacheHelper(profile), | 89 : BrowsingDataAppCacheHelper(browser_context), |
| 92 profile_(profile) { | 90 browser_context_(browser_context) { |
| 93 info_collection_ = new content::AppCacheInfoCollection; | 91 info_collection_ = new content::AppCacheInfoCollection; |
| 94 } | 92 } |
| 95 | 93 |
| 96 CannedBrowsingDataAppCacheHelper* CannedBrowsingDataAppCacheHelper::Clone() { | 94 CannedBrowsingDataAppCacheHelper* CannedBrowsingDataAppCacheHelper::Clone() { |
| 97 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 95 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
| 98 CannedBrowsingDataAppCacheHelper* clone = | 96 CannedBrowsingDataAppCacheHelper* clone = |
| 99 new CannedBrowsingDataAppCacheHelper(profile_); | 97 new CannedBrowsingDataAppCacheHelper(browser_context_); |
| 100 | 98 |
| 101 clone->info_collection_->infos_by_origin = info_collection_->infos_by_origin; | 99 clone->info_collection_->infos_by_origin = info_collection_->infos_by_origin; |
| 102 return clone; | 100 return clone; |
| 103 } | 101 } |
| 104 | 102 |
| 105 void CannedBrowsingDataAppCacheHelper::AddAppCache(const GURL& manifest_url) { | 103 void CannedBrowsingDataAppCacheHelper::AddAppCache(const GURL& manifest_url) { |
| 106 if (!BrowsingDataHelper::HasWebScheme(manifest_url)) | 104 if (!BrowsingDataHelper::HasWebScheme(manifest_url)) |
| 107 return; // Ignore non-websafe schemes. | 105 return; // Ignore non-websafe schemes. |
| 108 | 106 |
| 109 OriginAppCacheInfoMap& origin_map = info_collection_->infos_by_origin; | 107 OriginAppCacheInfoMap& origin_map = info_collection_->infos_by_origin; |
| (...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 151 completion_callback.Run(); | 149 completion_callback.Run(); |
| 152 } | 150 } |
| 153 | 151 |
| 154 void CannedBrowsingDataAppCacheHelper::DeleteAppCacheGroup( | 152 void CannedBrowsingDataAppCacheHelper::DeleteAppCacheGroup( |
| 155 const GURL& manifest_url) { | 153 const GURL& manifest_url) { |
| 156 info_collection_->infos_by_origin.erase(manifest_url.GetOrigin()); | 154 info_collection_->infos_by_origin.erase(manifest_url.GetOrigin()); |
| 157 BrowsingDataAppCacheHelper::DeleteAppCacheGroup(manifest_url); | 155 BrowsingDataAppCacheHelper::DeleteAppCacheGroup(manifest_url); |
| 158 } | 156 } |
| 159 | 157 |
| 160 CannedBrowsingDataAppCacheHelper::~CannedBrowsingDataAppCacheHelper() {} | 158 CannedBrowsingDataAppCacheHelper::~CannedBrowsingDataAppCacheHelper() {} |
| OLD | NEW |