Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef ANDROID_WEBVIEW_BROWSER_AW_PREF_STORE_H_ | 5 #ifndef COMPONENTS_CRONET_ANDROID_CRONET_PREF_STORE_H_ |
| 6 #define ANDROID_WEBVIEW_BROWSER_AW_PREF_STORE_H_ | 6 #define COMPONENTS_CRONET_ANDROID_CRONET_PREF_STORE_H_ |
| 7 | 7 |
| 8 #include <string> | 8 #include <string> |
| 9 | 9 |
| 10 #include "base/basictypes.h" | 10 #include "base/basictypes.h" |
| 11 #include "base/compiler_specific.h" | 11 #include "base/compiler_specific.h" |
| 12 #include "base/observer_list.h" | 12 #include "base/observer_list.h" |
| 13 #include "base/prefs/persistent_pref_store.h" | 13 #include "base/prefs/persistent_pref_store.h" |
| 14 #include "base/prefs/pref_value_map.h" | 14 #include "base/prefs/pref_value_map.h" |
| 15 | 15 |
| 16 // A light-weight prefstore implementation that keeps preferences | 16 // A light-weight prefstore implementation that keeps preferences |
| 17 // in a memory backed store. This is not a persistent prefstore -- we | 17 // in a memory backed store. This is not a persistent prefstore -- we |
| 18 // subclass the PersistentPrefStore here since it is needed by the | 18 // subclass the PersistentPrefStore here since it is needed by the |
| 19 // PrefService, which in turn is needed by the Autofill component. | 19 // PrefService, which in turn is needed by the Autofill component. |
|
mmenke
2015/04/01 15:46:14
As Helen said, the second sentence really makes no
bengr
2015/04/24 02:30:43
Done.
| |
| 20 class AwPrefStore : public PersistentPrefStore { | 20 // TODO(bengr): Move to base/prefs or some other shared location. |
| 21 class CronetPrefStore : public PersistentPrefStore { | |
|
mmenke
2015/04/01 15:46:14
Ok, so now I'm following why you needs a Persisten
mmenke
2015/04/01 15:46:14
We're actually going to be needing to use an on-di
bengr
2015/04/24 02:30:42
Done.
bengr
2015/04/24 02:30:43
Ack. Out of scope for this CL.
| |
| 21 public: | 22 public: |
| 22 AwPrefStore(); | 23 CronetPrefStore(); |
| 23 | 24 |
| 24 // Overriden from PrefStore. | 25 // Overrides from PrefStore: |
| 25 bool GetValue(const std::string& key, | 26 bool GetValue(const std::string& key, |
| 26 const base::Value** result) const override; | 27 const base::Value** result) const override; |
| 27 void AddObserver(PrefStore::Observer* observer) override; | 28 void AddObserver(PrefStore::Observer* observer) override; |
| 28 void RemoveObserver(PrefStore::Observer* observer) override; | 29 void RemoveObserver(PrefStore::Observer* observer) override; |
| 29 bool HasObservers() const override; | 30 bool HasObservers() const override; |
| 30 bool IsInitializationComplete() const override; | 31 bool IsInitializationComplete() const override; |
| 31 | 32 |
| 32 // PersistentPrefStore overrides: | 33 // PersistentPrefStore overrides: |
| 33 bool GetMutableValue(const std::string& key, base::Value** result) override; | 34 bool GetMutableValue(const std::string& key, |
| 35 base::Value** result) override; | |
|
mmenke
2015/04/01 15:46:14
Can this all fit on a single line? Looks like it
bengr
2015/04/24 02:30:43
Done.
| |
| 34 void ReportValueChanged(const std::string& key) override; | 36 void ReportValueChanged(const std::string& key) override; |
| 35 void SetValue(const std::string& key, base::Value* value) override; | 37 void SetValue(const std::string& key, base::Value* value) override; |
| 36 void SetValueSilently(const std::string& key, base::Value* value) override; | 38 void SetValueSilently(const std::string& key, |
| 39 base::Value* value) override; | |
|
mmenke
2015/04/01 15:46:14
nit: fix indent, or can this all fir on a single
bengr
2015/04/24 02:30:42
Done.
| |
| 37 void RemoveValue(const std::string& key) override; | 40 void RemoveValue(const std::string& key) override; |
| 38 bool ReadOnly() const override; | 41 bool ReadOnly() const override; |
| 39 PrefReadError GetReadError() const override; | 42 PrefReadError GetReadError() const override; |
| 40 PersistentPrefStore::PrefReadError ReadPrefs() override; | 43 PersistentPrefStore::PrefReadError ReadPrefs() override; |
| 41 void ReadPrefsAsync(ReadErrorDelegate* error_delegate) override; | 44 void ReadPrefsAsync(ReadErrorDelegate* error_delegate) override; |
| 42 void CommitPendingWrite() override {} | 45 void CommitPendingWrite() override {} |
| 43 | 46 |
| 44 protected: | 47 protected: |
| 45 ~AwPrefStore() override; | 48 ~CronetPrefStore() override; |
|
mmenke
2015/04/01 15:46:14
Suggest making this private - no one should be inh
bengr
2015/04/24 02:30:42
Done.
| |
| 46 | 49 |
| 47 private: | 50 private: |
| 48 // Stores the preference values. | 51 // Stores the preference values. |
| 49 PrefValueMap prefs_; | 52 PrefValueMap prefs_; |
| 50 | 53 |
| 51 ObserverList<PrefStore::Observer, true> observers_; | 54 ObserverList<PrefStore::Observer, true> observers_; |
| 52 | 55 |
| 53 DISALLOW_COPY_AND_ASSIGN(AwPrefStore); | 56 DISALLOW_COPY_AND_ASSIGN(CronetPrefStore); |
| 54 }; | 57 }; |
| 55 | 58 |
| 56 #endif // ANDROID_WEBVIEW_BROWSER_AW_PREF_STORE_H_ | 59 #endif // COMPONENTS_CRONET_ANDROID_CRONET_PREF_STORE_H_ |
| OLD | NEW |