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

Side by Side Diff: services/preferences/public/cpp/pref_store_impl.cc

Issue 2778643002: Pref service: Filter updates from read-only pref stores. (Closed)
Patch Set: Created 3 years, 9 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 unified diff | Download patch
OLDNEW
1 // Copyright 2017 The Chromium Authors. All rights reserved. 1 // Copyright 2017 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 #include "services/preferences/public/cpp/pref_store_impl.h" 5 #include "services/preferences/public/cpp/pref_store_impl.h"
6 6
7 #include <memory> 7 #include <memory>
8 #include <unordered_set>
8 9
10 #include "base/stl_util.h"
9 #include "base/values.h" 11 #include "base/values.h"
10 12
11 namespace prefs { 13 namespace prefs {
12 14
15 class PrefStoreImpl::Observer {
16 public:
17 Observer(mojom::PrefStoreObserverPtr observer,
18 std::unordered_set<std::string> prefs)
19 : observer_(std::move(observer)), prefs_(std::move(prefs)) {}
20
21 void OnInitializationCompleted(bool succeeded) {
22 observer_->OnInitializationCompleted(succeeded);
23 }
24
25 void OnPrefChanged(const std::string& key, const base::Value& value) const {
26 if (!base::ContainsKey(prefs_, key))
27 return;
28
29 observer_->OnPrefChanged(key, value.CreateDeepCopy());
30 }
31
32 void OnPrefRemoved(const std::string& key) const {
33 if (!base::ContainsKey(prefs_, key))
34 return;
35
36 observer_->OnPrefChanged(key, nullptr);
37 }
38
39 private:
40 mojom::PrefStoreObserverPtr observer_;
41 const std::unordered_set<std::string> prefs_;
42
43 DISALLOW_COPY_AND_ASSIGN(Observer);
44 };
45
13 PrefStoreImpl::PrefStoreImpl(scoped_refptr<::PrefStore> pref_store, 46 PrefStoreImpl::PrefStoreImpl(scoped_refptr<::PrefStore> pref_store,
14 mojom::PrefStoreRequest request) 47 mojom::PrefStoreRequest request)
15 : backing_pref_store_(std::move(pref_store)), 48 : backing_pref_store_(std::move(pref_store)),
16 backing_pref_store_initialized_(false), 49 backing_pref_store_initialized_(false),
17 binding_(this, std::move(request)) { 50 binding_(this, std::move(request)) {
18 DCHECK(backing_pref_store_); 51 DCHECK(backing_pref_store_);
19 if (backing_pref_store_->IsInitializationComplete()) 52 if (backing_pref_store_->IsInitializationComplete())
20 OnInitializationCompleted(true); 53 OnInitializationCompleted(true);
21 backing_pref_store_->AddObserver(this); 54 backing_pref_store_->AddObserver(this);
22 } 55 }
23 56
24 PrefStoreImpl::~PrefStoreImpl() { 57 PrefStoreImpl::~PrefStoreImpl() {
25 backing_pref_store_->RemoveObserver(this); 58 backing_pref_store_->RemoveObserver(this);
26 } 59 }
27 60
28 // static 61 // static
29 std::unique_ptr<PrefStoreImpl> PrefStoreImpl::Create( 62 std::unique_ptr<PrefStoreImpl> PrefStoreImpl::Create(
30 mojom::PrefStoreRegistryPtr registry_ptr, 63 mojom::PrefStoreRegistry* registry_ptr,
31 scoped_refptr<::PrefStore> pref_store, 64 scoped_refptr<::PrefStore> pref_store,
32 PrefValueStore::PrefStoreType type) { 65 PrefValueStore::PrefStoreType type) {
33 mojom::PrefStorePtr ptr; 66 mojom::PrefStorePtr ptr;
34 auto impl = base::MakeUnique<PrefStoreImpl>(std::move(pref_store), 67 auto impl = base::MakeUnique<PrefStoreImpl>(std::move(pref_store),
35 mojo::MakeRequest(&ptr)); 68 mojo::MakeRequest(&ptr));
36 registry_ptr->Register(type, std::move(ptr)); 69 registry_ptr->Register(type, std::move(ptr));
37 return impl; 70 return impl;
38 } 71 }
39 72
40 void PrefStoreImpl::OnPrefValueChanged(const std::string& key) { 73 void PrefStoreImpl::OnPrefValueChanged(const std::string& key) {
41 auto dictionary = base::MakeUnique<base::DictionaryValue>(); 74 auto dictionary = base::MakeUnique<base::DictionaryValue>();
42 const base::Value* value = nullptr; 75 const base::Value* value = nullptr;
43 if (backing_pref_store_->GetValue(key, &value)) { 76 if (backing_pref_store_->GetValue(key, &value)) {
44 for (const auto& observer : observers_) 77 for (const auto& observer : observers_)
45 observer->OnPrefChanged(key, value->CreateDeepCopy()); 78 observer->OnPrefChanged(key, *value);
46 } else { 79 } else {
47 for (const auto& observer : observers_) 80 for (const auto& observer : observers_)
48 observer->OnPrefChanged(key, nullptr); 81 observer->OnPrefRemoved(key);
49 } 82 }
50 } 83 }
51 84
52 void PrefStoreImpl::OnInitializationCompleted(bool succeeded) { 85 void PrefStoreImpl::OnInitializationCompleted(bool succeeded) {
53 // Some pref stores call this more than once. We just ignore all calls after 86 // Some pref stores call this more than once. We just ignore all calls after
54 // the first. 87 // the first.
55 if (backing_pref_store_initialized_) 88 if (backing_pref_store_initialized_)
56 DCHECK(succeeded); 89 DCHECK(succeeded);
57 backing_pref_store_initialized_ = succeeded; 90 backing_pref_store_initialized_ = succeeded;
58 for (const auto& observer : observers_) 91 for (const auto& observer : observers_)
59 observer->OnInitializationCompleted(succeeded); 92 observer->OnInitializationCompleted(succeeded);
60 } 93 }
61 94
62 void PrefStoreImpl::AddObserver(const AddObserverCallback& callback) { 95 void PrefStoreImpl::AddObserver(
96 const std::vector<std::string>& prefs_to_observe,
97 const AddObserverCallback& callback) {
63 mojom::PrefStoreObserverPtr observer_ptr; 98 mojom::PrefStoreObserverPtr observer_ptr;
64 auto request = mojo::MakeRequest(&observer_ptr); 99 auto request = mojo::MakeRequest(&observer_ptr);
65 observers_.push_back(std::move(observer_ptr)); 100 observers_.push_back(base::MakeUnique<Observer>(
101 std::move(observer_ptr),
102 std::unordered_set<std::string>(prefs_to_observe.begin(),
103 prefs_to_observe.end())));
66 callback.Run(mojom::PrefStoreConnection::New( 104 callback.Run(mojom::PrefStoreConnection::New(
67 std::move(request), backing_pref_store_->GetValues(), 105 std::move(request), backing_pref_store_->GetValues(),
68 backing_pref_store_->IsInitializationComplete())); 106 backing_pref_store_->IsInitializationComplete()));
69 } 107 }
70 108
71 } // namespace prefs 109 } // namespace prefs
OLDNEW
« no previous file with comments | « services/preferences/public/cpp/pref_store_impl.h ('k') | services/preferences/public/cpp/tests/BUILD.gn » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698