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

Unified Diff: chrome/browser/extensions/extension_settings_frontend.h

Issue 8177022: Add onChanged events to the extension settings API, both from sync and between (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: . Created 9 years, 2 months 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
Index: chrome/browser/extensions/extension_settings_frontend.h
diff --git a/chrome/browser/extensions/extension_settings_frontend.h b/chrome/browser/extensions/extension_settings_frontend.h
index 7fe3dc00b91ae9564be38b910b6cd4b1e2bad315..e19b955337b01e05350ff5ec45f88a5758d9ef04 100644
--- a/chrome/browser/extensions/extension_settings_frontend.h
+++ b/chrome/browser/extensions/extension_settings_frontend.h
@@ -6,56 +6,68 @@
#define CHROME_BROWSER_EXTENSIONS_EXTENSION_SETTINGS_FRONTEND_H_
#pragma once
+#include "base/callback.h"
#include "base/compiler_specific.h"
+#include "base/memory/linked_ptr.h"
#include "base/memory/ref_counted.h"
-#include "base/callback.h"
+#include "base/observer_list_threadsafe.h"
+#include "chrome/browser/extensions/extension_settings_observer.h"
#include "chrome/browser/sync/api/syncable_service.h"
+#include "content/common/notification_observer.h"
+#include "content/common/notification_registrar.h"
class FilePath;
+class Profile;
class ExtensionSettingsBackend;
class ExtensionSettingsStorage;
// The component of extension settings which runs on the UI thread, as opposed
// to ExtensionSettingsBackend which lives on the FILE thread.
-class ExtensionSettingsFrontend {
+class ExtensionSettingsFrontend : public NotificationObserver {
public:
- explicit ExtensionSettingsFrontend(const FilePath& base_path);
+ explicit ExtensionSettingsFrontend(Profile* profile);
+ virtual ~ExtensionSettingsFrontend();
typedef base::Callback<void(ExtensionSettingsBackend*)> BackendCallback;
// Runs |callback| on the FILE thread with the extension settings.
void RunWithBackend(const BackendCallback& callback);
- ~ExtensionSettingsFrontend();
+ // Adds an observer to settings changes.
+ void AddObserver(ExtensionSettingsObserver* observer);
- private:
- // Ref-counted container for the ExtensionSettingsBackend object.
- class Core : public base::RefCountedThreadSafe<Core> {
- public:
- // Constructed on UI thread.
- Core();
+ // Removes an observer to settings changes.
+ void RemoveObserver(ExtensionSettingsObserver* observer);
- // Does any FILE thread specific initialization, such as construction of
- // |backend_|. Must be called before any call to
- // RunWithBackendOnFileThread().
- void InitOnFileThread(const FilePath& base_path);
+ // NotificationObserver implementation.
+ virtual void Observe(
+ int type,
+ const NotificationSource& source,
+ const NotificationDetails& details) OVERRIDE;
- // Runs |callback| with the extension backend.
- void RunWithBackendOnFileThread(const BackendCallback& callback);
+ private:
+ // Called when a profile is created.
+ void OnProfileCreated(Profile* profile);
- private:
- // Can be destroyed on either the UI or FILE thread.
- virtual ~Core();
- friend class base::RefCountedThreadSafe<Core>;
+ // Called when a profile is destroyed.
+ void OnProfileDestroyed(Profile* profile);
- // Lives on the FILE thread.
- ExtensionSettingsBackend* backend_;
+ // List of observers to settings changes.
+ scoped_refptr<ObserverListThreadSafe<ExtensionSettingsObserver> > observers_;
- DISALLOW_COPY_AND_ASSIGN(Core);
- };
+ // Map of Profiles to their Observers. This is so that when Profiles are
+ // destroyed we can remove the associated Observer.
+ // MUST ONLY BE ACCESSED ON THE UI THREAD.
+ class DefaultObserver;
+ std::map<Profile*, linked_ptr<DefaultObserver> > profile_observers_;
+ // Ref-counted container for the ExtensionSettingsBackend object.
+ class Core;
scoped_refptr<Core> core_;
+ // For profile created/destroyed notifications.
+ NotificationRegistrar registrar_;
+
DISALLOW_COPY_AND_ASSIGN(ExtensionSettingsFrontend);
};

Powered by Google App Engine
This is Rietveld 408576698