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

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

Issue 5915004: Introduce incognito preference settings. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Continued work from last year Created 9 years, 12 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_pref_store.h
diff --git a/chrome/browser/extensions/extension_pref_store.h b/chrome/browser/extensions/extension_pref_store.h
index f2db8096692e56a7523af315865ee76d8d2d0b5c..a469ee091bd2e854c30a60687e64458453286f92 100644
--- a/chrome/browser/extensions/extension_pref_store.h
+++ b/chrome/browser/extensions/extension_pref_store.h
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// Copyright (c) 2011 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
@@ -6,31 +6,64 @@
#define CHROME_BROWSER_EXTENSIONS_EXTENSION_PREF_STORE_H_
#pragma once
-#include "chrome/browser/prefs/value_map_pref_store.h"
+#include <map>
+#include <set>
-// A PrefStore implementation that holds preferences set by extensions.
-class ExtensionPrefStore : public ValueMapPrefStore {
- public:
- ExtensionPrefStore();
- virtual ~ExtensionPrefStore() {}
+#include "base/time.h"
+#include "chrome/browser/prefs/value_map_pref_store.h"
- // Set an extension preference |value| for |key|. Takes ownership of |value|.
- void SetExtensionPref(const std::string& key, Value* value);
+class ExtensionPrefValueMap;
- // Remove the extension preference value for |key|.
- void RemoveExtensionPref(const std::string& key);
+// A (non-persistent) PrefStore implementation that holds preferences set by
+// extensions.
+// The semantics of the ExtensionPrefStore are:
+// - The precedence of extensions is determined by their installation time.
+// The extension that has been installed later takes higher precedence.
+// - If two extensions set a value for the same preference, the following
+// rules determine which value becomes effective (visible).
+// - The effective regular extension pref value is determined by the regular
+// extension pref value of the extension with the highest precedence.
+// - The effective incognito extension pref value is determined by the incognito
+// extension pref value of the extension with the highest precedence, unless
+// another extension with higher precedence overrides it with a regular
+// extension pref value.
+//
+// The following table illustrates the behavior:
+// A.reg | A.inc | B.reg | B.inc | E.reg | E.inc
+// 1 | - | - | - | 1 | 1
+// 1 | 2 | - | - | 1 | 2
+// 1 | - | 3 | - | 3 | 3
+// 1 | - | - | 4 | 1 | 4
+// 1 | 2 | 3 | - | 3 | 3(!)
+// 1 | 2 | - | 4 | 1 | 4
+// 1 | 2 | 3 | 4 | 3 | 4
+// A = extension A, B = extension B, E = effective value
+// .reg = regular value
+// .inc = incognito value
+// Extension B has higher precedence than A.
+//
+// Large parts of ExtensionPrefStore's logic are implemented in
+// ExtensionPrefValueMap.
Mattias Nissler (ping if slow) 2011/01/05 12:08:07 Maybe it's useful to put the semantics comment abo
battre 2011/01/05 20:23:08 Done.
+class ExtensionPrefStore : public ValueMapPrefStore,
+ public PrefStore::Observer {
+ public:
+ // Constructs an ExtensionPrefStore for a regular or an incognito profile.
+ explicit ExtensionPrefStore(bool incognito_pref_store);
+ virtual ~ExtensionPrefStore();
- // Tell the store it's now fully initialized.
- void OnInitializationCompleted();
+ // Does not assume ownership of |extension_pref_value_map|.
+ void SetExtensionPrefValueMap(
+ ExtensionPrefValueMap* extension_pref_value_map);
Mattias Nissler (ping if slow) 2011/01/05 12:08:07 Why can't we pass this to the constructor?
battre 2011/01/05 20:23:08 Done.
private:
- // PrefStore overrides:
- virtual bool IsInitializationComplete() const;
+ // Overrides for PrefStore::Observer:
+ virtual void OnInitializationCompleted();
+ virtual void OnPrefValueChanged(const std::string& key);
- bool initialization_complete_;
+ ExtensionPrefValueMap* extension_pref_value_map_; // Weak pointer.
+ bool incognito_pref_store_;
DISALLOW_COPY_AND_ASSIGN(ExtensionPrefStore);
};
-
#endif // CHROME_BROWSER_EXTENSIONS_EXTENSION_PREF_STORE_H_
« no previous file with comments | « no previous file | chrome/browser/extensions/extension_pref_store.cc » ('j') | chrome/browser/extensions/extension_pref_value_map.h » ('J')

Powered by Google App Engine
This is Rietveld 408576698