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

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

Issue 21580002: Add histograms to track synced pref changes. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 7 years, 4 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
(Empty)
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "chrome/browser/prefs/synced_pref_change_registrar.h"
6
7 #include "base/bind.h"
8
9 namespace {
10
11 void InvokeUnnamedCallback(
12 const SyncedPrefChangeRegistrar::ChangeCallback& callback,
13 const std::string& path, bool from_sync) {
battre 2013/08/06 15:54:39 nit: each parameter into a new line.
Ken Rockot(use gerrit already) 2013/08/06 20:18:32 Done.
14 callback.Run(from_sync);
15 }
16
17 } // namespace
18
19 SyncedPrefChangeRegistrar::SyncedPrefChangeRegistrar(
20 PrefServiceSyncable* pref_service) {
21 pref_service_ = pref_service;
22 }
23
24 SyncedPrefChangeRegistrar::~SyncedPrefChangeRegistrar() {
25 RemoveAll();
26 }
27
28 void SyncedPrefChangeRegistrar::Add(const char *path,
battre 2013/08/06 15:54:39 nit: align parameters
Ken Rockot(use gerrit already) 2013/08/06 20:18:32 Done.
29 const ChangeCallback& callback) {
30 Add(path, base::Bind(InvokeUnnamedCallback, callback));
31 }
32
33 void SyncedPrefChangeRegistrar::Add(const char *path,
34 const NamedChangeCallback& callback) {
35 DCHECK(!IsObserved(path));
36 observers_[path] = callback;
37 pref_service_->AddSyncedPrefObserver(path, this);
38 }
39
40 void SyncedPrefChangeRegistrar::Remove(const char *path) {
41 observers_.erase(path);
42 pref_service_->RemoveSyncedPrefObserver(path, this);
43 }
44
45 void SyncedPrefChangeRegistrar::RemoveAll() {
46 for (ObserverMap::iterator iter = observers_.begin();
47 iter != observers_.end(); ++iter) {
battre 2013/08/06 15:54:39 nit: +1 space indent
Ken Rockot(use gerrit already) 2013/08/06 20:18:32 Done.
48 pref_service_->RemoveSyncedPrefObserver(iter->first, this);
49 }
50 observers_.clear();
51 }
52
53 bool SyncedPrefChangeRegistrar::IsObserved(const char* path) const {
54 return observers_.find(path) != observers_.end();
55 }
56
57 void SyncedPrefChangeRegistrar::OnSyncedPrefChanged(const std::string& path,
battre 2013/08/06 15:54:39 nit: align parameters.
Ken Rockot(use gerrit already) 2013/08/06 20:18:32 Done.
58 bool from_sync) {
59 ObserverMap::const_iterator iter = observers_.find(path);
60 if (iter == observers_.end())
61 return;
62 iter->second.Run(path, from_sync);
63 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698