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

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

Issue 1326353002: Remove dependency of PrefSyncableService on Profile. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@pref_model_associator
Patch Set: Move files back to //chrome/browser/prefs & //chrome/test/base Created 5 years, 3 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 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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/synced_pref_change_registrar.h" 5 #include "chrome/browser/prefs/synced_pref_change_registrar.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 8
9 namespace { 9 namespace {
10 10
11 void InvokeUnnamedCallback( 11 void InvokeUnnamedCallback(
12 const SyncedPrefChangeRegistrar::ChangeCallback& callback, 12 const SyncedPrefChangeRegistrar::ChangeCallback& callback,
13 const std::string& path, 13 const std::string& path,
14 bool from_sync) { 14 bool from_sync) {
15 callback.Run(from_sync); 15 callback.Run(from_sync);
16 } 16 }
17 17
18 } // namespace 18 } // namespace
19 19
20 SyncedPrefChangeRegistrar::SyncedPrefChangeRegistrar( 20 SyncedPrefChangeRegistrar::SyncedPrefChangeRegistrar(
21 PrefServiceSyncable* pref_service) { 21 PrefServiceSyncable* pref_service) {
22 pref_service_ = pref_service; 22 pref_service_ = pref_service;
23 } 23 }
24 24
25 SyncedPrefChangeRegistrar::~SyncedPrefChangeRegistrar() { 25 SyncedPrefChangeRegistrar::~SyncedPrefChangeRegistrar() {
26 RemoveAll(); 26 RemoveAll();
27 } 27 }
28 28
29 void SyncedPrefChangeRegistrar::Add(const char *path, 29 void SyncedPrefChangeRegistrar::Add(const char* path,
30 const ChangeCallback& callback) { 30 const ChangeCallback& callback) {
31 Add(path, base::Bind(InvokeUnnamedCallback, callback)); 31 Add(path, base::Bind(InvokeUnnamedCallback, callback));
32 } 32 }
33 33
34 void SyncedPrefChangeRegistrar::Add(const char *path, 34 void SyncedPrefChangeRegistrar::Add(const char* path,
35 const NamedChangeCallback& callback) { 35 const NamedChangeCallback& callback) {
36 DCHECK(!IsObserved(path)); 36 DCHECK(!IsObserved(path));
37 observers_[path] = callback; 37 observers_[path] = callback;
38 pref_service_->AddSyncedPrefObserver(path, this); 38 pref_service_->AddSyncedPrefObserver(path, this);
39 } 39 }
40 40
41 void SyncedPrefChangeRegistrar::Remove(const char *path) { 41 void SyncedPrefChangeRegistrar::Remove(const char* path) {
42 observers_.erase(path); 42 observers_.erase(path);
43 pref_service_->RemoveSyncedPrefObserver(path, this); 43 pref_service_->RemoveSyncedPrefObserver(path, this);
44 } 44 }
45 45
46 void SyncedPrefChangeRegistrar::RemoveAll() { 46 void SyncedPrefChangeRegistrar::RemoveAll() {
47 for (ObserverMap::iterator iter = observers_.begin(); 47 for (ObserverMap::iterator iter = observers_.begin();
48 iter != observers_.end(); ++iter) { 48 iter != observers_.end(); ++iter) {
49 pref_service_->RemoveSyncedPrefObserver(iter->first, this); 49 pref_service_->RemoveSyncedPrefObserver(iter->first, this);
50 } 50 }
51 observers_.clear(); 51 observers_.clear();
52 } 52 }
53 53
54 bool SyncedPrefChangeRegistrar::IsObserved(const char* path) const { 54 bool SyncedPrefChangeRegistrar::IsObserved(const char* path) const {
55 return observers_.find(path) != observers_.end(); 55 return observers_.find(path) != observers_.end();
56 } 56 }
57 57
58 void SyncedPrefChangeRegistrar::OnSyncedPrefChanged(const std::string& path, 58 void SyncedPrefChangeRegistrar::OnSyncedPrefChanged(const std::string& path,
59 bool from_sync) { 59 bool from_sync) {
60 if (pref_service_->IsManagedPreference(path.c_str())) 60 if (pref_service_->IsManagedPreference(path.c_str()))
61 return; 61 return;
62 ObserverMap::const_iterator iter = observers_.find(path); 62 ObserverMap::const_iterator iter = observers_.find(path);
63 if (iter == observers_.end()) 63 if (iter == observers_.end())
64 return; 64 return;
65 iter->second.Run(path, from_sync); 65 iter->second.Run(path, from_sync);
66 } 66 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698