Index: chrome/browser/ui/app_list/extension_app_model_builder.cc |
diff --git a/chrome/browser/ui/app_list/extension_app_model_builder.cc b/chrome/browser/ui/app_list/extension_app_model_builder.cc |
index fdf191cc2126a305335d34c6273ab2ff1d51b1e3..13ebea934b286ac02712741c6e9d34a325844c60 100644 |
--- a/chrome/browser/ui/app_list/extension_app_model_builder.cc |
+++ b/chrome/browser/ui/app_list/extension_app_model_builder.cc |
@@ -10,7 +10,6 @@ |
#include "base/bind.h" |
#include "base/callback.h" |
#include "base/command_line.h" |
-#include "chrome/browser/chrome_notification_types.h" |
#include "chrome/browser/extensions/extension_ui_util.h" |
#include "chrome/browser/extensions/install_tracker.h" |
#include "chrome/browser/extensions/install_tracker_factory.h" |
@@ -20,8 +19,8 @@ |
#include "chrome/browser/ui/app_list/app_list_syncable_service_factory.h" |
#include "chrome/browser/ui/app_list/extension_app_item.h" |
#include "chrome/common/chrome_switches.h" |
-#include "content/public/browser/notification_service.h" |
#include "extensions/browser/extension_prefs.h" |
+#include "extensions/browser/extension_registry.h" |
#include "extensions/browser/extension_system.h" |
#include "extensions/browser/extensions_browser_client.h" |
#include "extensions/browser/pref_names.h" |
@@ -38,7 +37,8 @@ ExtensionAppModelBuilder::ExtensionAppModelBuilder( |
controller_(controller), |
model_(NULL), |
highlighted_app_pending_(false), |
- tracker_(NULL) { |
+ tracker_(NULL), |
+ extension_registry_(NULL) { |
} |
ExtensionAppModelBuilder::~ExtensionAppModelBuilder() { |
@@ -124,7 +124,9 @@ void ExtensionAppModelBuilder::OnInstallFailure( |
model_->DeleteItem(extension_id); |
} |
-void ExtensionAppModelBuilder::OnExtensionLoaded(const Extension* extension) { |
+void ExtensionAppModelBuilder::OnExtensionLoaded( |
+ content::BrowserContext* browser_context, |
+ const extensions::Extension* extension) { |
if (!extensions::ui_util::ShouldDisplayInAppLauncher(extension, profile_)) |
return; |
@@ -145,7 +147,10 @@ void ExtensionAppModelBuilder::OnExtensionLoaded(const Extension* extension) { |
UpdateHighlight(); |
} |
-void ExtensionAppModelBuilder::OnExtensionUnloaded(const Extension* extension) { |
+void ExtensionAppModelBuilder::OnExtensionUnloaded( |
+ content::BrowserContext* browser_context, |
+ const extensions::Extension* extension, |
+ extensions::UnloadedExtensionInfo::Reason reason) { |
ExtensionAppItem* item = GetExtensionAppItem(extension->id()); |
if (!item) |
return; |
@@ -153,7 +158,8 @@ void ExtensionAppModelBuilder::OnExtensionUnloaded(const Extension* extension) { |
} |
void ExtensionAppModelBuilder::OnExtensionUninstalled( |
- const Extension* extension) { |
+ content::BrowserContext* browser_context, |
+ const extensions::Extension* extension) { |
if (service_) { |
DVLOG(2) << service_ << ": OnExtensionUninstalled: " |
<< extension->id().substr(0, 8); |
@@ -183,6 +189,10 @@ void ExtensionAppModelBuilder::OnShutdown() { |
tracker_->RemoveObserver(this); |
tracker_ = NULL; |
} |
+ if (extension_registry_) { |
+ extension_registry_->RemoveObserver(this); |
+ extension_registry_ = NULL; |
+ } |
} |
scoped_ptr<ExtensionAppItem> ExtensionAppModelBuilder::CreateAppItem( |
@@ -203,6 +213,7 @@ scoped_ptr<ExtensionAppItem> ExtensionAppModelBuilder::CreateAppItem( |
void ExtensionAppModelBuilder::BuildModel() { |
DCHECK(!tracker_); |
tracker_ = controller_->GetInstallTrackerFor(profile_); |
+ extension_registry_ = extensions::ExtensionRegistry::Get(profile_); |
PopulateApps(); |
UpdateHighlight(); |
@@ -210,6 +221,9 @@ void ExtensionAppModelBuilder::BuildModel() { |
// Start observing after model is built. |
if (tracker_) |
tracker_->AddObserver(this); |
+ |
+ if (extension_registry_) |
+ extension_registry_->AddObserver(this); |
} |
void ExtensionAppModelBuilder::PopulateApps() { |