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

Unified Diff: chrome/browser/chromeos/cros_settings.cc

Issue 8091002: PART2: Make SignedSettings use proper Value types instead of string all around the place. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Addressed comments and rebased on a the current PART1 version. Created 9 years, 2 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/chromeos/cros_settings.cc
diff --git a/chrome/browser/chromeos/cros_settings.cc b/chrome/browser/chromeos/cros_settings.cc
index 7162907fe0a1679e1cbad666d322872c1c073f01..64cac072d3d73a55b2db87b8ca59603f26222654 100644
--- a/chrome/browser/chromeos/cros_settings.cc
+++ b/chrome/browser/chromeos/cros_settings.cc
@@ -47,7 +47,7 @@ void CrosSettings::FireObservers(const char* path) {
}
}
-void CrosSettings::Set(const std::string& path, Value* in_value) {
+void CrosSettings::Set(const std::string& path, const base::Value& in_value) {
DCHECK(CalledOnValidThread());
CrosSettingsProvider* provider;
provider = GetProvider(path);
@@ -58,23 +58,47 @@ void CrosSettings::Set(const std::string& path, Value* in_value) {
void CrosSettings::SetBoolean(const std::string& path, bool in_value) {
DCHECK(CalledOnValidThread());
- Set(path, Value::CreateBooleanValue(in_value));
+ base::FundamentalValue value(in_value);
+ Set(path, value);
Denis Lagno 2011/10/13 13:43:10 nit: why not pass const reference to temporary obj
Mattias Nissler (ping if slow) 2011/10/13 14:49:52 clang won't like it.
pastarmovj 2011/10/26 15:44:59 Exactly, sad but true fact :(
}
void CrosSettings::SetInteger(const std::string& path, int in_value) {
DCHECK(CalledOnValidThread());
- Set(path, Value::CreateIntegerValue(in_value));
+ base::FundamentalValue value(in_value);
+ Set(path, value);
Denis Lagno 2011/10/13 13:43:10 ditto
}
void CrosSettings::SetDouble(const std::string& path, double in_value) {
DCHECK(CalledOnValidThread());
- Set(path, Value::CreateDoubleValue(in_value));
+ base::FundamentalValue value(in_value);
+ Set(path, value);
Denis Lagno 2011/10/13 13:43:10 ditto
}
void CrosSettings::SetString(const std::string& path,
const std::string& in_value) {
DCHECK(CalledOnValidThread());
- Set(path, Value::CreateStringValue(in_value));
+ base::StringValue value(in_value);
+ Set(path, value);
Denis Lagno 2011/10/13 13:43:10 ditto
+}
+
+void CrosSettings::AppendToList(const std::string& path,
+ const base::Value& value) {
+ DCHECK(CalledOnValidThread());
+ const base::Value* old_value = GetPref(path);
+ scoped_ptr<base::Value> new_value(
+ old_value ? old_value->DeepCopy() : new base::ListValue());
+ static_cast<base::ListValue*>(new_value.get())->Append(value.DeepCopy());
+ Set(path, *new_value);
+}
+
+void CrosSettings::RemoveFromList(const std::string& path,
+ const base::Value& value) {
+ DCHECK(CalledOnValidThread());
+ const base::Value* old_value = GetPref(path);
+ scoped_ptr<base::Value> new_value(
+ old_value ? old_value->DeepCopy() : new base::ListValue());
+ static_cast<base::ListValue*>(new_value.get())->Remove(value, NULL);
+ Set(path, *new_value);
}
bool CrosSettings::AddSettingsProvider(CrosSettingsProvider* provider) {

Powered by Google App Engine
This is Rietveld 408576698