OLD | NEW |
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 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/extensions/image_loading_tracker.h" | 5 #include "chrome/browser/extensions/image_loading_tracker.h" |
6 | 6 |
7 #include "base/file_util.h" | 7 #include "base/file_util.h" |
8 #include "chrome/browser/browser_thread.h" | 8 #include "chrome/browser/browser_thread.h" |
9 #include "chrome/common/extensions/extension.h" | 9 #include "chrome/common/extensions/extension.h" |
10 #include "chrome/common/extensions/extension_resource.h" | 10 #include "chrome/common/extensions/extension_resource.h" |
(...skipping 105 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
116 }; | 116 }; |
117 | 117 |
118 //////////////////////////////////////////////////////////////////////////////// | 118 //////////////////////////////////////////////////////////////////////////////// |
119 // ImageLoadingTracker | 119 // ImageLoadingTracker |
120 | 120 |
121 ImageLoadingTracker::ImageLoadingTracker(Observer* observer) | 121 ImageLoadingTracker::ImageLoadingTracker(Observer* observer) |
122 : observer_(observer), | 122 : observer_(observer), |
123 next_id_(0) { | 123 next_id_(0) { |
124 registrar_.Add(this, NotificationType::EXTENSION_UNLOADED, | 124 registrar_.Add(this, NotificationType::EXTENSION_UNLOADED, |
125 NotificationService::AllSources()); | 125 NotificationService::AllSources()); |
126 registrar_.Add(this, NotificationType::EXTENSION_UNLOADED_DISABLED, | |
127 NotificationService::AllSources()); | |
128 } | 126 } |
129 | 127 |
130 ImageLoadingTracker::~ImageLoadingTracker() { | 128 ImageLoadingTracker::~ImageLoadingTracker() { |
131 // The loader is created lazily and is NULL if the tracker is destroyed before | 129 // The loader is created lazily and is NULL if the tracker is destroyed before |
132 // any valid image load tasks have been posted. | 130 // any valid image load tasks have been posted. |
133 if (loader_) | 131 if (loader_) |
134 loader_->StopTracking(); | 132 loader_->StopTracking(); |
135 } | 133 } |
136 | 134 |
137 void ImageLoadingTracker::LoadImage(const Extension* extension, | 135 void ImageLoadingTracker::LoadImage(const Extension* extension, |
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
177 original_size); | 175 original_size); |
178 load_map_.erase(i); | 176 load_map_.erase(i); |
179 } | 177 } |
180 | 178 |
181 observer_->OnImageLoaded(image, resource, id); | 179 observer_->OnImageLoaded(image, resource, id); |
182 } | 180 } |
183 | 181 |
184 void ImageLoadingTracker::Observe(NotificationType type, | 182 void ImageLoadingTracker::Observe(NotificationType type, |
185 const NotificationSource& source, | 183 const NotificationSource& source, |
186 const NotificationDetails& details) { | 184 const NotificationDetails& details) { |
187 DCHECK(type == NotificationType::EXTENSION_UNLOADED || | 185 DCHECK(type == NotificationType::EXTENSION_UNLOADED); |
188 type == NotificationType::EXTENSION_UNLOADED_DISABLED); | |
189 | 186 |
190 const Extension* extension = Details<const Extension>(details).ptr(); | 187 const Extension* extension = |
| 188 Details<UnloadedExtensionInfo>(details)->extension; |
191 | 189 |
192 // Remove all entries in the load_map_ referencing the extension. This ensures | 190 // Remove all entries in the load_map_ referencing the extension. This ensures |
193 // we don't attempt to cache the image when the load completes. | 191 // we don't attempt to cache the image when the load completes. |
194 for (LoadMap::iterator i = load_map_.begin(); i != load_map_.end();) { | 192 for (LoadMap::iterator i = load_map_.begin(); i != load_map_.end();) { |
195 if (i->second == extension) { | 193 if (i->second == extension) { |
196 load_map_.erase(i++); | 194 load_map_.erase(i++); |
197 } else { | 195 } else { |
198 ++i; | 196 ++i; |
199 } | 197 } |
200 } | 198 } |
201 } | 199 } |
OLD | NEW |