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

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

Issue 5915004: Introduce incognito preference settings. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Addressed comments Created 10 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
Index: chrome/browser/extensions/extension_prefs.h
diff --git a/chrome/browser/extensions/extension_prefs.h b/chrome/browser/extensions/extension_prefs.h
index 8c8be82e15eb3db056902a833e593fe705c2bad3..3daca6a9f8222745e4b12fc2edbe2cf8b8346745 100644
--- a/chrome/browser/extensions/extension_prefs.h
+++ b/chrome/browser/extensions/extension_prefs.h
@@ -11,6 +11,7 @@
#include <vector>
#include "base/linked_ptr.h"
+#include "base/ref_counted.h"
#include "base/time.h"
#include "chrome/browser/prefs/pref_service.h"
#include "chrome/common/extensions/extension.h"
@@ -59,9 +60,12 @@ class ExtensionPrefs {
LAUNCH_WINDOW
};
+ // Does not assume owner ship of |prefs| and |incognito_prefs|.
danno 2010/12/22 10:48:21 nit: s/owner ship/ownership/
Mattias Nissler (ping if slow) 2010/12/22 12:09:03 s/owner ship/ownership/
battre 2010/12/22 18:34:53 Done.
battre 2010/12/22 18:34:53 Done.
explicit ExtensionPrefs(PrefService* prefs,
+ PrefService* incognito_prefs,
const FilePath& root_dir,
- ExtensionPrefStore* extension_pref_store);
+ ExtensionPrefStore* extension_pref_store,
+ ExtensionPrefStore* incognito_pref_store);
Mattias Nissler (ping if slow) 2010/12/22 12:09:03 It worries me that we need the incognito_prefs poi
battre 2010/12/22 18:34:53 Will do this in the next patch set of this CL.
~ExtensionPrefs();
// Returns a copy of the Extensions prefs.
@@ -263,6 +267,7 @@ class ExtensionPrefs {
// global the extension wants to override.
void SetExtensionControlledPref(const std::string& extension_id,
const std::string& pref_key,
+ bool incognito,
Value* value);
static void RegisterUserPrefs(PrefService* prefs);
@@ -335,9 +340,10 @@ class ExtensionPrefs {
DictionaryValue* GetExtensionPref(const std::string& id) const;
// Returns the dictionary of preferences controlled by the specified extension
- // or NULL if unknown. All entries in the dictionary contain non-expanded
+ // or creates a new one. All entries in the dictionary contain non-expanded
// paths.
- DictionaryValue* GetExtensionControlledPrefs(const std::string& id) const;
+ DictionaryValue* GetExtensionControlledPrefs(const std::string& id,
+ bool incognito) const;
// Serializes the data and schedules a persistent save via the |PrefService|.
// Additionally fires a PREF_CHANGED notification with the top-level
@@ -370,7 +376,7 @@ class ExtensionPrefs {
// Returns the extension controlled preference value of the extension that was
// installed most recently.
const Value* GetWinningExtensionControlledPrefValue(
- const std::string& key) const;
+ const std::string& key, bool incognito) const;
// Executes UpdatePrefStore for all |pref_keys|.
void UpdatePrefStore(const PrefKeySet& pref_keys);
@@ -378,21 +384,24 @@ class ExtensionPrefs {
// Finds the most recently installed extension that defines a preference
// for |pref_key|, then stores its value in the PrefValueStore's extension
// pref store and sends notifications to observers in case the value changed.
- void UpdatePrefStore(const std::string& pref_key);
+ void UpdatePrefStore(const std::string& pref_key, bool incognito);
// Retrieves a list of preference keys that the specified extension
// intends to manage. Keys are always appended, |out| is not cleared.
void GetExtensionControlledPrefKeys(const std::string& extension_id,
PrefKeySet *out) const;
- // The pref service specific to this set of extension prefs.
+ // The pref service specific to this set of extension prefs. Owned by profile.
PrefService* prefs_;
+ PrefService* incognito_prefs_;
// Base extensions install directory.
FilePath install_directory_;
// Used to manipulate extension preferences.
- ExtensionPrefStore* pref_store_;
+ scoped_refptr<ExtensionPrefStore> pref_store_;
+ // Shared with PrefValueStore of |incognito_prefs_|.
+ scoped_refptr<ExtensionPrefStore> incognito_pref_store_;
// The URLs of all of the toolstrips.
URLList shelf_order_;
« no previous file with comments | « no previous file | chrome/browser/extensions/extension_prefs.cc » ('j') | chrome/browser/extensions/extension_prefs.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698