Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 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 | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "blimp/client/core/settings/settings.h" | |
| 6 | |
| 7 #include "base/bind.h" | |
| 8 #include "base/command_line.h" | |
| 9 #include "blimp/client/core/settings/settings_observer.h" | |
| 10 #include "blimp/client/core/switches/blimp_client_switches.h" | |
| 11 #include "components/prefs/pref_registry_simple.h" | |
| 12 | |
| 13 namespace blimp { | |
| 14 namespace client { | |
| 15 | |
| 16 const CommandLinePrefStore::BooleanSwitchToPreferenceMapEntry | |
| 17 Settings::boolean_switch_map_[] = { | |
| 18 {blimp::switches::kEnableBlimp, prefs::kBlimpEnabled, true}, | |
| 19 {blimp::switches::kDownloadWholeDocument, | |
| 20 prefs::kRecordWholeDocument, true}, | |
| 21 }; | |
| 22 | |
| 23 Settings::Settings(PrefService* local_state) | |
| 24 : local_state_(local_state), | |
| 25 show_network_stats_(false) { | |
| 26 pref_change_registrar_.Init(local_state); | |
| 27 pref_change_registrar_.Add( | |
| 28 prefs::kBlimpEnabled, | |
| 29 base::Bind(&Settings::OnPreferenceChanged, base::Unretained(this), | |
| 30 local_state, prefs::kBlimpEnabled)); | |
| 31 pref_change_registrar_.Add( | |
| 32 prefs::kRecordWholeDocument, | |
| 33 base::Bind(&Settings::OnPreferenceChanged, base::Unretained(this), | |
| 34 local_state, prefs::kRecordWholeDocument)); | |
| 35 } | |
| 36 | |
| 37 Settings::~Settings() = default; | |
| 38 | |
| 39 void Settings::AddObserver(SettingsObserver* observer) { | |
| 40 observers_.AddObserver(observer); | |
| 41 } | |
| 42 | |
| 43 void Settings::RemoveObserver(SettingsObserver* observer) { | |
| 44 observers_.RemoveObserver(observer); | |
| 45 } | |
| 46 | |
| 47 void Settings::SetShowNetworkStats(bool enable) { | |
| 48 if (show_network_stats_ == enable) | |
| 49 return; | |
| 50 | |
| 51 show_network_stats_ = enable; | |
| 52 for (auto& observer : observers_) { | |
| 53 observer.OnShowNetworkStatsChanged(show_network_stats_); | |
|
Bernhard Bauer
2016/10/25 14:30:50
Nit: For the if-statement above, you leave out bra
Menglin
2016/10/25 18:32:52
Done.
| |
| 54 } | |
| 55 } | |
| 56 | |
| 57 void Settings::SetEnableBlimpMode(bool enable) { | |
| 58 local_state_->SetBoolean(prefs::kBlimpEnabled, enable); | |
| 59 } | |
| 60 | |
| 61 void Settings::SetRecordWholeDocument(bool enable) { | |
| 62 local_state_->SetBoolean(prefs::kRecordWholeDocument, enable); | |
| 63 } | |
| 64 | |
| 65 void Settings::OnPreferenceChanged( | |
| 66 PrefService* service, const std::string& pref_name) { | |
| 67 if (pref_name == prefs::kBlimpEnabled) { | |
| 68 for (auto& observer : observers_) { | |
| 69 observer.OnBlimpModeEnabled(service->GetBoolean(pref_name)); | |
| 70 } | |
| 71 for (auto& observer : observers_) { | |
|
Bernhard Bauer
2016/10/25 14:30:50
Is it intentional that this will iterate over all
Menglin
2016/10/25 18:32:52
should do it once and call both methods. I was jus
| |
| 72 observer.OnRestartRequired(); | |
| 73 } | |
| 74 } else if (pref_name == prefs::kRecordWholeDocument) { | |
| 75 for (auto& observer : observers_) { | |
| 76 observer.OnRecordWholeDocumentChanged(service->GetBoolean(pref_name)); | |
| 77 } | |
| 78 } | |
| 79 } | |
| 80 | |
| 81 // static | |
| 82 void Settings::RegisterPrefs(PrefRegistrySimple* registry) { | |
| 83 registry->RegisterBooleanPref(prefs::kBlimpEnabled, false); | |
| 84 registry->RegisterBooleanPref(prefs::kRecordWholeDocument, false); | |
| 85 } | |
| 86 | |
| 87 // static | |
| 88 void Settings::ApplyBlimpSwitches(CommandLinePrefStore* store) { | |
| 89 store->ApplyBooleanSwitches(boolean_switch_map_, | |
| 90 arraysize(boolean_switch_map_)); | |
| 91 } | |
| 92 | |
| 93 } // namespace client | |
| 94 } // namespace blimp | |
| OLD | NEW |