Index: chrome/browser/ui/app_list/app_list_prefs.cc |
diff --git a/chrome/browser/ui/app_list/app_list_prefs.cc b/chrome/browser/ui/app_list/app_list_prefs.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..2b70a76b67ce6b3dd00a37e92449575689a72657 |
--- /dev/null |
+++ b/chrome/browser/ui/app_list/app_list_prefs.cc |
@@ -0,0 +1,122 @@ |
+// 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 "base/prefs/pref_service.h" |
+#include "base/prefs/scoped_user_pref_update.h" |
+#include "chrome/browser/ui/app_list/app_list_prefs.h" |
+#include "chrome/browser/ui/app_list/app_list_prefs_factory.h" |
+#include "components/pref_registry/pref_registry_syncable.h" |
+ |
+namespace app_list { |
+ |
+namespace { |
+ |
+// App list ordering and folder data. |
+const char kPrefModel[] = "app_list.model"; |
+ |
+const char kModelItemPosition[] = "position"; |
+const char kModelItemType[] = "item_type"; |
+const char kModelItemFolderId[] = "folder_id"; |
+const char kModelItemName[] = "name"; |
+ |
+} // namespace |
+ |
+// static |
+void AppListPrefs::RegisterProfilePrefs( |
+ user_prefs::PrefRegistrySyncable* registry) { |
+ registry->RegisterDictionaryPref( |
+ kPrefModel, user_prefs::PrefRegistrySyncable::UNSYNCABLE_PREF); |
+} |
+ |
+// static |
+AppListPrefs* AppListPrefs::Create(PrefService* pref_service) { |
+ return new AppListPrefs(pref_service); |
+} |
+ |
+// static |
+AppListPrefs* AppListPrefs::Get(content::BrowserContext* context) { |
+ return AppListPrefsFactory::GetInstance()->GetForBrowserContext(context); |
+} |
+ |
+AppListPrefs::AppListInfo::AppListInfo(const base::DictionaryValue* item_dict) { |
Matt Giuca
2014/09/30 02:49:46
Add comments delineating the methods of different
calamity
2014/09/30 05:40:08
Done.
|
+ std::string item_ordinal_string; |
+ int item_type_int = -1; |
+ if (!item_dict->GetString(kModelItemPosition, &item_ordinal_string) || |
+ !item_dict->GetString(kModelItemFolderId, &folder_id) || |
+ !item_dict->GetString(kModelItemName, &name) || |
+ !item_dict->GetInteger(kModelItemType, &item_type_int) || |
+ item_type_int < AppListInfo::ITEM_TYPE_BEGIN || |
+ item_type_int > AppListInfo::ITEM_TYPE_END) { |
+ item_type = AppListInfo::ITEM_TYPE_INVALID; |
Matt Giuca
2014/09/30 02:49:47
Return early; no else.
calamity
2014/09/30 05:40:08
Done.
|
+ } else { |
+ position = syncer::StringOrdinal(item_ordinal_string); |
+ item_type = static_cast<ItemType>(item_type_int); |
+ } |
+} |
+ |
+AppListPrefs::AppListInfo::AppListInfo() : item_type(ITEM_TYPE_INVALID) { |
+} |
+ |
+AppListPrefs::AppListInfo::~AppListInfo() { |
+} |
+ |
+AppListPrefs::AppListPrefs(PrefService* pref_service) |
+ : pref_service_(pref_service) { |
+} |
+ |
+AppListPrefs::~AppListPrefs() { |
+} |
+ |
+void AppListPrefs::SetAppListInfo(const std::string& id, |
+ const AppListPrefs::AppListInfo& info) { |
+ DictionaryPrefUpdate update(pref_service_, kPrefModel); |
+ scoped_ptr<base::DictionaryValue> info_dict(new base::DictionaryValue()); |
Matt Giuca
2014/09/30 02:49:46
I think this should be a method on AppListInfo:
s
calamity
2014/09/30 05:40:08
Done.
|
+ info_dict->Set(kModelItemPosition, |
+ new base::StringValue(info.position.ToInternalValue())); |
+ info_dict->Set(kModelItemFolderId, new base::StringValue(info.folder_id)); |
+ info_dict->Set(kModelItemName, new base::StringValue(info.name)); |
+ info_dict->Set(kModelItemType, new base::FundamentalValue(info.item_type)); |
Matt Giuca
2014/09/30 02:49:46
Should this be static_cast too?
calamity
2014/09/30 05:40:07
Hmm. Doesn't seem to need to be.
|
+ update->Set(id, info_dict.release()); |
+} |
+ |
+scoped_ptr<AppListPrefs::AppListInfo> AppListPrefs::GetAppListInfo( |
+ const std::string& id) const { |
+ const base::DictionaryValue* model_dict = |
+ pref_service_->GetDictionary(kPrefModel); |
+ const base::DictionaryValue* item_dict = NULL; |
+ if (!model_dict || !model_dict->GetDictionary(id, &item_dict)) { |
+ return scoped_ptr<AppListInfo>(); |
+ } |
+ |
+ scoped_ptr<AppListInfo> info(new AppListInfo(item_dict)); |
+ if (info->item_type == AppListInfo::ITEM_TYPE_INVALID) |
+ return scoped_ptr<AppListInfo>(); |
+ |
+ return info.Pass(); |
+} |
+ |
+std::map<std::string, AppListPrefs::AppListInfo> |
+AppListPrefs::GetAllAppListInfos() const { |
+ const base::DictionaryValue* model_dict = |
+ pref_service_->GetDictionary(kPrefModel); |
+ std::map<std::string, AppListInfo> infos; |
+ if (!model_dict) |
+ return infos; |
+ |
+ for (base::DictionaryValue::Iterator it(*model_dict); !it.IsAtEnd(); |
+ it.Advance()) { |
+ const base::DictionaryValue* item_dict = NULL; |
+ it.value().GetAsDictionary(&item_dict); |
+ DCHECK(item_dict); |
+ infos[it.key()] = AppListInfo(item_dict); |
+ } |
+ return infos; |
+} |
+ |
+void AppListPrefs::DeleteAppListInfo(const std::string& id) { |
+ DictionaryPrefUpdate model_dict(pref_service_, kPrefModel); |
+ model_dict->Remove(id, NULL); |
+} |
+ |
+} // namespace app_list |