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

Side by Side Diff: chrome/browser/prefs/preferences_manager.cc

Issue 2635093002: Switch Preferences to use Factory (Closed)
Patch Set: Missed test Created 3 years, 11 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 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 "chrome/browser/prefs/preferences_manager.h" 5 #include "chrome/browser/prefs/preferences_manager.h"
6 6
7 #include "base/auto_reset.h" 7 #include "base/auto_reset.h"
8 #include "base/bind.h" 8 #include "base/bind.h"
9 #include "base/memory/ptr_util.h" 9 #include "base/memory/ptr_util.h"
10 #include "base/values.h" 10 #include "base/values.h"
11 #include "chrome/browser/profiles/profile.h" 11 #include "chrome/browser/profiles/profile.h"
12 #include "components/prefs/pref_change_registrar.h" 12 #include "components/prefs/pref_change_registrar.h"
13 #include "components/prefs/pref_service.h" 13 #include "components/prefs/pref_service.h"
14 14
15 PreferencesManager::PreferencesManager(Profile* profile) 15 PreferencesManager::PreferencesManager(
16 prefs::mojom::PreferencesObserverPtr client,
17 Profile* profile)
16 : preferences_change_registrar_(new PrefChangeRegistrar), 18 : preferences_change_registrar_(new PrefChangeRegistrar),
19 client_(std::move(client)),
17 setting_preferences_(false) { 20 setting_preferences_(false) {
18 DCHECK(profile); 21 DCHECK(profile);
22 DCHECK(client_.is_bound());
19 service_ = profile->GetPrefs(); 23 service_ = profile->GetPrefs();
20 preferences_change_registrar_->Init(service_); 24 preferences_change_registrar_->Init(service_);
21 } 25 }
22 26
23 PreferencesManager::~PreferencesManager() {} 27 PreferencesManager::~PreferencesManager() {}
24 28
25 void PreferencesManager::PreferenceChanged(const std::string& preference_name) { 29 void PreferencesManager::PreferenceChanged(const std::string& preference_name) {
26 if (setting_preferences_) 30 if (setting_preferences_)
27 return; 31 return;
28 const PrefService::Preference* pref = 32 const PrefService::Preference* pref =
29 service_->FindPreference(preference_name); 33 service_->FindPreference(preference_name);
30 std::unique_ptr<base::DictionaryValue> dictionary = 34 std::unique_ptr<base::DictionaryValue> dictionary =
31 base::MakeUnique<base::DictionaryValue>(); 35 base::MakeUnique<base::DictionaryValue>();
32 dictionary->Set(preference_name, pref->GetValue()->CreateDeepCopy()); 36 dictionary->Set(preference_name, pref->GetValue()->CreateDeepCopy());
33 client_->OnPreferencesChanged(std::move(dictionary)); 37 client_->OnPreferencesChanged(std::move(dictionary));
34 } 38 }
35 39
36 void PreferencesManager::AddObserver(
37 prefs::mojom::PreferencesObserverPtr client) {
38 // TODO(jonross): once service_manager::Connector supports enforcing two-way
39 // binding at connection time, update PreferencesManager to use that approach.
40 // After which enforcing bind checks will not be needed (crbug.com/674140)
41 client_ = std::move(client);
42 }
43
44 void PreferencesManager::SetPreferences( 40 void PreferencesManager::SetPreferences(
45 std::unique_ptr<base::DictionaryValue> preferences) { 41 std::unique_ptr<base::DictionaryValue> preferences) {
46 if (!client_.is_bound())
47 return;
48 DCHECK(!setting_preferences_); 42 DCHECK(!setting_preferences_);
49 // We ignore preference changes caused by us. 43 // We ignore preference changes caused by us.
50 base::AutoReset<bool> setting_preferences(&setting_preferences_, true); 44 base::AutoReset<bool> setting_preferences(&setting_preferences_, true);
51 for (base::DictionaryValue::Iterator it(*preferences); !it.IsAtEnd(); 45 for (base::DictionaryValue::Iterator it(*preferences); !it.IsAtEnd();
52 it.Advance()) { 46 it.Advance()) {
53 if (!preferences_change_registrar_->IsObserved(it.key())) 47 if (!preferences_change_registrar_->IsObserved(it.key()))
54 continue; 48 continue;
55 const PrefService::Preference* pref = service_->FindPreference(it.key()); 49 const PrefService::Preference* pref = service_->FindPreference(it.key());
56 if (!pref) { 50 if (!pref) {
57 DLOG(ERROR) << "Preference " << it.key() << " not found.\n"; 51 DLOG(ERROR) << "Preference " << it.key() << " not found.\n";
58 continue; 52 continue;
59 } 53 }
60 if (it.value().Equals(pref->GetValue())) 54 if (it.value().Equals(pref->GetValue()))
61 continue; 55 continue;
62 service_->Set(it.key(), it.value()); 56 service_->Set(it.key(), it.value());
63 } 57 }
64 } 58 }
65 59
66 void PreferencesManager::Subscribe( 60 void PreferencesManager::Subscribe(
67 const std::vector<std::string>& preferences) { 61 const std::vector<std::string>& preferences) {
68 if (!client_.is_bound())
69 return;
70 std::unique_ptr<base::DictionaryValue> dictionary = 62 std::unique_ptr<base::DictionaryValue> dictionary =
71 base::MakeUnique<base::DictionaryValue>(); 63 base::MakeUnique<base::DictionaryValue>();
72 for (auto& it : preferences) { 64 for (auto& it : preferences) {
73 const PrefService::Preference* pref = service_->FindPreference(it); 65 const PrefService::Preference* pref = service_->FindPreference(it);
74 if (!pref) { 66 if (!pref) {
75 DLOG(ERROR) << "Preference " << it << " not found.\n"; 67 DLOG(ERROR) << "Preference " << it << " not found.\n";
76 continue; 68 continue;
77 } 69 }
78 // PreferenceManager lifetime is managed by a mojo::StrongBindingPtr owned 70 // PreferenceManager lifetime is managed by a mojo::StrongBindingPtr owned
79 // by PreferenceConnectionManager. It will outlive 71 // by PreferenceConnectionManager. It will outlive
80 // |preferences_change_registrar_| which it owns. 72 // |preferences_change_registrar_| which it owns.
81 preferences_change_registrar_->Add( 73 preferences_change_registrar_->Add(
82 it, base::Bind(&PreferencesManager::PreferenceChanged, 74 it, base::Bind(&PreferencesManager::PreferenceChanged,
83 base::Unretained(this))); 75 base::Unretained(this)));
84 dictionary->Set(it, pref->GetValue()->CreateDeepCopy()); 76 dictionary->Set(it, pref->GetValue()->CreateDeepCopy());
85 } 77 }
86 78
87 if (dictionary->empty()) 79 if (dictionary->empty())
88 return; 80 return;
89 client_->OnPreferencesChanged(std::move(dictionary)); 81 client_->OnPreferencesChanged(std::move(dictionary));
90 } 82 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698