Chromium Code Reviews| Index: chrome/browser/prefs/preferences_manager.cc |
| diff --git a/chrome/browser/prefs/preferences_manager.cc b/chrome/browser/prefs/preferences_manager.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..40830ff565b2e03cc848d31a5c7c5e865df2aae0 |
| --- /dev/null |
| +++ b/chrome/browser/prefs/preferences_manager.cc |
| @@ -0,0 +1,85 @@ |
| +// Copyright 2016 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. |
| + |
| +#include "chrome/browser/prefs/preferences_manager.h" |
| + |
| +#include "base/auto_reset.h" |
| +#include "base/bind.h" |
| +#include "base/values.h" |
| +#include "chrome/browser/profiles/profile.h" |
| +#include "components/prefs/pref_change_registrar.h" |
| +#include "components/prefs/pref_service.h" |
| + |
| +PreferencesManager::PreferencesManager(Profile* profile) |
| + : preferences_change_registrar_(new PrefChangeRegistrar), |
| + setting_preferences_(false) { |
| + DCHECK(profile); |
| + service_ = profile->GetPrefs(); |
| + preferences_change_registrar_->Init(service_); |
| +} |
| + |
| +PreferencesManager::~PreferencesManager() {} |
| + |
| +void PreferencesManager::PreferenceChanged(const std::string& preference_name) { |
| + if (setting_preferences_) |
| + return; |
| + const PrefService::Preference* pref = |
| + service_->FindPreference(preference_name); |
| + base::DictionaryValue dictionary; |
| + dictionary.Set(preference_name, pref->GetValue()->CreateDeepCopy()); |
| + client_->OnPreferencesChanged(dictionary); |
| +} |
| + |
| +void PreferencesManager::AddObserver( |
| + prefs::mojom::PreferencesObserverPtr client) { |
| + // TODO(jonross): once service_manager::Connector supports enforcing two-way |
| + // binding at connection time, update PreferencesManager to use that approach. |
| + // After which enforcing bind checks will not be needed (crbug.com/674140) |
| + client_ = std::move(client); |
| +} |
| + |
| +void PreferencesManager::SetPreferences( |
| + const base::DictionaryValue& preferences) { |
| + DCHECK(client_.is_bound()); |
|
dcheng
2016/12/15 16:17:08
This should be an if (...) with an early return.
jonross
2016/12/19 15:58:13
Done.
|
| + DCHECK(!setting_preferences_); |
| + // We ignore preference changes caused by us. |
| + base::AutoReset<bool> setting_preferences(&setting_preferences_, true); |
| + for (base::DictionaryValue::Iterator it(preferences); !it.IsAtEnd(); |
| + it.Advance()) { |
| + if (!preferences_change_registrar_->IsObserved(it.key())) |
| + continue; |
| + const PrefService::Preference* pref = service_->FindPreference(it.key()); |
| + if (!pref) { |
| + DLOG(ERROR) << "Preference " << it.key() << " not found.\n"; |
| + continue; |
| + } |
| + if (it.value().Equals(pref->GetValue())) |
| + continue; |
| + service_->Set(it.key(), it.value()); |
| + } |
| +} |
| + |
| +void PreferencesManager::Subscribe( |
| + const std::vector<std::string>& preferences) { |
| + DCHECK(client_.is_bound()); |
| + base::DictionaryValue dictionary; |
| + for (auto& it : preferences) { |
| + const PrefService::Preference* pref = service_->FindPreference(it); |
| + if (!pref) { |
| + DLOG(ERROR) << "Preference " << it << " not found.\n"; |
| + continue; |
| + } |
| + // PreferenceManager lifetime is managed by a mojo::StrongBindingPtr owned |
| + // by PreferenceConnectionManager. It will outlive |
| + // |preferences_change_registrar_| which it owns. |
| + preferences_change_registrar_->Add( |
| + it, base::Bind(&PreferencesManager::PreferenceChanged, |
| + base::Unretained(this))); |
| + dictionary.Set(it, pref->GetValue()->CreateDeepCopy()); |
| + } |
| + |
| + if (dictionary.empty()) |
| + return; |
| + client_->OnPreferencesChanged(dictionary); |
| +} |