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

Unified Diff: chrome/browser/icon_manager.cc

Issue 2577273002: Clean up IconLoader. (Closed)
Patch Set: bind Created 4 years 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chrome/browser/icon_manager.h ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/icon_manager.cc
diff --git a/chrome/browser/icon_manager.cc b/chrome/browser/icon_manager.cc
index 1796f417fadcd22cc2d0d79625b8daa2ceb88b63..7b20ef323a79675a2357d52ab5c286a5c206d12a 100644
--- a/chrome/browser/icon_manager.cc
+++ b/chrome/browser/icon_manager.cc
@@ -25,14 +25,7 @@ void RunCallbackIfNotCanceled(
} // namespace
-struct IconManager::ClientRequest {
- IconRequestCallback callback;
- base::FilePath file_path;
- IconLoader::IconSize size;
-};
-
-IconManager::IconManager() {
-}
+IconManager::IconManager() : weak_factory_(this) {}
IconManager::~IconManager() {
}
@@ -56,48 +49,39 @@ base::CancelableTaskTracker::TaskId IconManager::LoadIcon(
IconLoader::IconSize size,
const IconRequestCallback& callback,
base::CancelableTaskTracker* tracker) {
- IconLoader* loader = new IconLoader(file_path, size, this);
- loader->AddRef();
- loader->Start();
-
base::CancelableTaskTracker::IsCanceledCallback is_canceled;
base::CancelableTaskTracker::TaskId id =
tracker->NewTrackedTaskId(&is_canceled);
IconRequestCallback callback_runner = base::Bind(
&RunCallbackIfNotCanceled, is_canceled, callback);
- requests_[loader] = {callback_runner, file_path, size};
+ IconLoader* loader = IconLoader::Create(
+ file_path, size,
+ base::Bind(&IconManager::OnIconLoaded, weak_factory_.GetWeakPtr(),
+ callback_runner, file_path, size));
+ loader->Start();
+
return id;
}
-// IconLoader::Delegate implementation -----------------------------------------
-
-void IconManager::OnImageLoaded(IconLoader* loader,
- std::unique_ptr<gfx::Image> result,
- const IconLoader::IconGroup& group) {
- auto request_it = requests_.find(loader);
- DCHECK(request_it != requests_.end());
-
- // Balances the AddRef() in LoadIcon().
- loader->Release();
-
- const ClientRequest& client_request = request_it->second;
-
+void IconManager::OnIconLoaded(IconRequestCallback callback,
+ base::FilePath file_path,
+ IconLoader::IconSize size,
+ std::unique_ptr<gfx::Image> result,
+ const IconLoader::IconGroup& group) {
// Cache the bitmap. Watch out: |result| may be null, which indicates a
// failure. We assume that if we have an entry in |icon_cache_| it must not be
// null.
- CacheKey key(group, client_request.size);
+ CacheKey key(group, size);
if (result) {
- client_request.callback.Run(result.get());
+ callback.Run(result.get());
icon_cache_[key] = std::move(result);
} else {
- client_request.callback.Run(nullptr);
+ callback.Run(nullptr);
icon_cache_.erase(key);
}
- group_cache_[client_request.file_path] = group;
-
- requests_.erase(request_it);
+ group_cache_[file_path] = group;
}
IconManager::CacheKey::CacheKey(const IconLoader::IconGroup& group,
« no previous file with comments | « chrome/browser/icon_manager.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698