Chromium Code Reviews| 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_ |