OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 BASE_PREFS_JSON_PREF_STORE_H_ | 5 #ifndef BASE_PREFS_JSON_PREF_STORE_H_ |
6 #define BASE_PREFS_JSON_PREF_STORE_H_ | 6 #define BASE_PREFS_JSON_PREF_STORE_H_ |
7 | 7 |
8 #include <set> | 8 #include <set> |
9 #include <string> | 9 #include <string> |
10 | 10 |
11 #include "base/basictypes.h" | 11 #include "base/basictypes.h" |
12 #include "base/compiler_specific.h" | 12 #include "base/compiler_specific.h" |
13 #include "base/files/file_path.h" | 13 #include "base/files/file_path.h" |
14 #include "base/files/important_file_writer.h" | |
15 #include "base/memory/scoped_ptr.h" | 14 #include "base/memory/scoped_ptr.h" |
16 #include "base/message_loop/message_loop_proxy.h" | 15 #include "base/message_loop/message_loop_proxy.h" |
17 #include "base/observer_list.h" | 16 #include "base/observer_list.h" |
18 #include "base/prefs/base_prefs_export.h" | |
19 #include "base/prefs/persistent_pref_store.h" | 17 #include "base/prefs/persistent_pref_store.h" |
20 | 18 #include "base/prefs/pref_value_map.h" |
21 class PrefFilter; | 19 #include "base/timer/timer.h" |
22 | 20 |
23 namespace base { | 21 namespace base { |
24 class DictionaryValue; | 22 class DictionaryValue; |
25 class FilePath; | |
26 class SequencedTaskRunner; | 23 class SequencedTaskRunner; |
27 class SequencedWorkerPool; | |
28 class Value; | 24 class Value; |
29 } | 25 } |
30 | 26 |
27 namespace leveldb { | |
28 class DB; | |
29 } | |
31 | 30 |
32 // A writable PrefStore implementation that is used for user preferences. | 31 // A writable PrefStore implementation that is used for user preferences. |
33 class BASE_PREFS_EXPORT JsonPrefStore | 32 class BASE_PREFS_EXPORT LevelDBPrefStore : public PersistentPrefStore { |
34 : public PersistentPrefStore, | |
35 public base::ImportantFileWriter::DataSerializer { | |
36 public: | 33 public: |
37 // Returns instance of SequencedTaskRunner which guarantees that file | |
38 // operations on the same file will be executed in sequenced order. | |
39 static scoped_refptr<base::SequencedTaskRunner> GetTaskRunnerForFile( | |
40 const base::FilePath& pref_filename, | |
41 base::SequencedWorkerPool* worker_pool); | |
42 | |
43 // |sequenced_task_runner| is must be a shutdown-blocking task runner, ideally | 34 // |sequenced_task_runner| is must be a shutdown-blocking task runner, ideally |
44 // created by GetTaskRunnerForFile() method above. | 35 // created by GetTaskRunnerForFile() method above. |
45 JsonPrefStore(const base::FilePath& pref_filename, | 36 LevelDBPrefStore(const base::FilePath& pref_filename, |
46 base::SequencedTaskRunner* sequenced_task_runner, | 37 base::SequencedTaskRunner* sequenced_task_runner); |
47 scoped_ptr<PrefFilter> pref_filter); | |
48 | 38 |
49 // PrefStore overrides: | 39 // PrefStore overrides: |
50 virtual bool GetValue(const std::string& key, | 40 virtual bool GetValue(const std::string& key, |
51 const base::Value** result) const OVERRIDE; | 41 const base::Value** result) const OVERRIDE; |
52 virtual void AddObserver(PrefStore::Observer* observer) OVERRIDE; | 42 virtual void AddObserver(PrefStore::Observer* observer) OVERRIDE; |
53 virtual void RemoveObserver(PrefStore::Observer* observer) OVERRIDE; | 43 virtual void RemoveObserver(PrefStore::Observer* observer) OVERRIDE; |
54 virtual bool HasObservers() const OVERRIDE; | 44 virtual bool HasObservers() const OVERRIDE; |
55 virtual bool IsInitializationComplete() const OVERRIDE; | 45 virtual bool IsInitializationComplete() const OVERRIDE; |
56 | 46 |
57 // PersistentPrefStore overrides: | 47 // PersistentPrefStore overrides: |
58 virtual bool GetMutableValue(const std::string& key, | 48 virtual bool GetMutableValue(const std::string& key, |
59 base::Value** result) OVERRIDE; | 49 base::Value** result) OVERRIDE; |
50 // Takes ownership of value. | |
60 virtual void SetValue(const std::string& key, base::Value* value) OVERRIDE; | 51 virtual void SetValue(const std::string& key, base::Value* value) OVERRIDE; |
61 virtual void SetValueSilently(const std::string& key, | 52 virtual void SetValueSilently(const std::string& key, |
62 base::Value* value) OVERRIDE; | 53 base::Value* value) OVERRIDE; |
63 virtual void RemoveValue(const std::string& key) OVERRIDE; | 54 virtual void RemoveValue(const std::string& key) OVERRIDE; |
64 virtual bool ReadOnly() const OVERRIDE; | 55 virtual bool ReadOnly() const OVERRIDE; |
65 virtual PrefReadError GetReadError() const OVERRIDE; | 56 virtual PrefReadError GetReadError() const OVERRIDE; |
66 virtual PrefReadError ReadPrefs() OVERRIDE; | 57 virtual PrefReadError ReadPrefs() OVERRIDE; |
67 virtual void ReadPrefsAsync(ReadErrorDelegate* error_delegate) OVERRIDE; | 58 virtual void ReadPrefsAsync(ReadErrorDelegate* error_delegate) OVERRIDE; |
68 virtual void CommitPendingWrite() OVERRIDE; | 59 virtual void CommitPendingWrite() OVERRIDE; |
69 virtual void ReportValueChanged(const std::string& key) OVERRIDE; | 60 virtual void ReportValueChanged(const std::string& key) OVERRIDE; |
70 | 61 |
71 // This method is called after JSON file has been read. Method takes | 62 private: |
72 // ownership of the |value| pointer. Note, this method is used with | 63 struct ReadingResults; |
73 // asynchronous file reading, so class exposes it only for the internal needs. | 64 class FileThreadSerializer; |
74 // (read: do not call it manually). | |
75 void OnFileRead(base::Value* value_owned, PrefReadError error, bool no_dir); | |
76 | 65 |
77 private: | 66 virtual ~LevelDBPrefStore(); |
78 virtual ~JsonPrefStore(); | |
79 | 67 |
80 // ImportantFileWriter::DataSerializer overrides: | 68 static scoped_ptr<ReadingResults> DoReading(const base::FilePath& path); |
81 virtual bool SerializeData(std::string* output) OVERRIDE; | 69 static void OpenDB(const base::FilePath& path, |
70 ReadingResults* reading_results); | |
71 void OnStorageRead(scoped_ptr<ReadingResults> reading_results); | |
72 | |
73 void PersistFromUIThread(); | |
74 void RemoveFromUIThread(const std::string& key); | |
75 void ScheduleWrite(); | |
76 | |
77 void SetValueInternal(const std::string& key, | |
78 base::Value* value, | |
79 bool notify); | |
80 void NotifyObservers(const std::string& key); | |
81 void MarkForInsertion(const std::string& key, const std::string& value); | |
82 void MarkForDeletion(const std::string& key); | |
82 | 83 |
83 base::FilePath path_; | 84 base::FilePath path_; |
85 | |
84 const scoped_refptr<base::SequencedTaskRunner> sequenced_task_runner_; | 86 const scoped_refptr<base::SequencedTaskRunner> sequenced_task_runner_; |
87 const scoped_refptr<base::SequencedTaskRunner> original_task_runner_; | |
85 | 88 |
86 scoped_ptr<base::DictionaryValue> prefs_; | 89 PrefValueMap prefs_; |
87 | 90 |
88 bool read_only_; | 91 bool read_only_; |
89 | 92 |
90 // Helper for safely writing pref data. | |
91 base::ImportantFileWriter writer_; | |
92 | |
93 scoped_ptr<PrefFilter> pref_filter_; | |
94 ObserverList<PrefStore::Observer, true> observers_; | 93 ObserverList<PrefStore::Observer, true> observers_; |
95 | 94 |
96 scoped_ptr<ReadErrorDelegate> error_delegate_; | 95 scoped_ptr<ReadErrorDelegate> error_delegate_; |
97 | 96 |
98 bool initialized_; | 97 bool initialized_; |
99 PrefReadError read_error_; | 98 PrefReadError read_error_; |
100 | 99 |
101 std::set<std::string> keys_need_empty_value_; | 100 // This object is created on the UI thread right after preferences are loaded |
101 // from disk. A message to delete it is sent to the FILE thread by | |
102 // ~LevelDBPrefStore. | |
103 scoped_ptr<FileThreadSerializer> serializer_; | |
104 std::set<std::string> keys_to_delete_; | |
Mattias Nissler (ping if slow)
2014/04/14 10:11:41
Please document |keys_to_delete_|, |keys_to_set_|
dgrogan
2014/04/17 01:10:27
Done.
| |
105 std::map<std::string, std::string> keys_to_set_; | |
106 base::OneShotTimer<LevelDBPrefStore> timer_; | |
102 | 107 |
103 DISALLOW_COPY_AND_ASSIGN(JsonPrefStore); | 108 base::WeakPtrFactory<LevelDBPrefStore> weak_ptr_factory_; |
109 | |
110 DISALLOW_COPY_AND_ASSIGN(LevelDBPrefStore); | |
104 }; | 111 }; |
105 | 112 |
106 #endif // BASE_PREFS_JSON_PREF_STORE_H_ | 113 #endif // BASE_PREFS_JSON_PREF_STORE_H_ |
OLD | NEW |