Index: components/dom_distiller/core/distilled_page_prefs.cc |
diff --git a/components/dom_distiller/core/distilled_page_prefs.cc b/components/dom_distiller/core/distilled_page_prefs.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..2c32cae882508627fc6e91c4df7e0f616b09885d |
--- /dev/null |
+++ b/components/dom_distiller/core/distilled_page_prefs.cc |
@@ -0,0 +1,69 @@ |
+// Copyright 2014 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 "components/dom_distiller/core/distilled_page_prefs.h" |
+ |
+#include "base/bind.h" |
+#include "base/memory/weak_ptr.h" |
+#include "base/message_loop/message_loop.h" |
+#include "base/observer_list.h" |
+#include "base/prefs/pref_service.h" |
+#include "components/pref_registry/pref_registry_syncable.h" |
+ |
+namespace { |
+ |
+// Path to the integer corresponding to user's preference theme. |
+const char kThemePref[] = "dom_distiller.theme"; |
+ |
+} |
+ |
+namespace dom_distiller { |
+ |
+DistilledPagePrefs::DistilledPagePrefs(PrefService* pref_service) |
+ : pref_service_(pref_service), |
+ weak_ptr_factory_(this) { |
+} |
+ |
+DistilledPagePrefs::~DistilledPagePrefs() { |
+} |
+ |
+// static |
+void DistilledPagePrefs::RegisterProfilePrefs( |
+ user_prefs::PrefRegistrySyncable* registry) { |
+ registry->RegisterIntegerPref(kThemePref, |
+ Theme::kLight, |
+ user_prefs::PrefRegistrySyncable::SYNCABLE_PREF); |
+} |
+ |
+void DistilledPagePrefs::SetTheme(Theme new_theme) { |
+ if (new_theme >= Theme::kThemeCount) { |
nyquist
2014/07/08 22:26:47
When a parameter is already an enum you don't have
smaslo
2014/07/09 19:42:25
Done.
|
+ new_theme = Theme::kLight; |
+ } |
+ pref_service_->SetInteger(kThemePref, new_theme); |
+ base::MessageLoop::current()->PostTask(FROM_HERE, |
+ base::Bind(&DistilledPagePrefs::NotifyOnChangeTheme, |
+ weak_ptr_factory_.GetWeakPtr(), new_theme)); |
+} |
+ |
+const DistilledPagePrefs::Theme DistilledPagePrefs::GetTheme() { |
+ if (pref_service_->GetInteger(kThemePref) >= Theme::kThemeCount) { |
nyquist
2014/07/08 22:26:48
You also need to check for negative values. How ab
smaslo
2014/07/09 19:42:25
Done.
|
+ SetTheme(Theme::kLight); |
nyquist
2014/07/08 22:26:48
I think you could:
1) read to local variable
2) bo
smaslo
2014/07/09 19:42:25
Done.
|
+ } |
+ return (Theme) pref_service_->GetInteger(kThemePref); |
nyquist
2014/07/08 22:26:48
I don't think you want to read from disk again her
smaslo
2014/07/09 19:42:25
Done.
|
+} |
+ |
+void DistilledPagePrefs::AddObserver(Observer* obs) { |
+ observers_.AddObserver(obs); |
+} |
+ |
+void DistilledPagePrefs::RemoveObserver(Observer* obs) { |
+ observers_.RemoveObserver(obs); |
+} |
+ |
+void DistilledPagePrefs::NotifyOnChangeTheme(Theme new_theme) { |
+ FOR_EACH_OBSERVER(Observer, observers_, OnChangeTheme(new_theme)); |
+} |
+ |
+} // namespace dom_distiller |
+ |