 Chromium Code Reviews
 Chromium Code Reviews Issue 2352353002:
  Add AppLauncherId wrapper for items shown in shelf  (Closed)
    
  
    Issue 2352353002:
  Add AppLauncherId wrapper for items shown in shelf  (Closed) 
  | Index: chrome/browser/ui/ash/chrome_launcher_prefs.cc | 
| diff --git a/chrome/browser/ui/ash/chrome_launcher_prefs.cc b/chrome/browser/ui/ash/chrome_launcher_prefs.cc | 
| index c600e1eb486f4518d20632f454704c597f6ead62..a5d3e04c7a416b9609c943630ccb0bc8c6f3d921 100644 | 
| --- a/chrome/browser/ui/ash/chrome_launcher_prefs.cc | 
| +++ b/chrome/browser/ui/ash/chrome_launcher_prefs.cc | 
| @@ -42,7 +42,7 @@ const char* kDefaultPinnedApps[] = { | 
| base::ListValue* CreateDefaultPinnedAppsList() { | 
| std::unique_ptr<base::ListValue> apps(new base::ListValue); | 
| for (size_t i = 0; i < arraysize(kDefaultPinnedApps); ++i) | 
| - apps->Append(CreateAppDict(kDefaultPinnedApps[i])); | 
| + apps->Append(CreateAppDict(AppLauncherId(kDefaultPinnedApps[i]))); | 
| return apps.release(); | 
| } | 
| @@ -206,10 +206,12 @@ void PropagatePrefToLocalIfNotSet( | 
| } | 
| struct PinInfo { | 
| - PinInfo(const std::string& app_id, const syncer::StringOrdinal& item_ordinal) | 
| - : app_id(app_id), item_ordinal(item_ordinal) {} | 
| + PinInfo(const AppLauncherId& app_launcher_id, | 
| + const syncer::StringOrdinal& item_ordinal) | 
| + : app_launcher_id(app_launcher_id.GetAsString()), | 
| + item_ordinal(item_ordinal) {} | 
| - std::string app_id; | 
| + std::string app_launcher_id; | 
| syncer::StringOrdinal item_ordinal; | 
| }; | 
| @@ -223,23 +225,23 @@ struct ComparePinInfo { | 
| // to check if app exists in the list. | 
| class AppTracker { | 
| public: | 
| - bool HasApp(const std::string& app_id) const { | 
| - return app_set_.find(app_id) != app_set_.end(); | 
| + bool HasApp(const AppLauncherId& app_launcher_id) const { | 
| + return app_set_.find(app_launcher_id.GetAsString()) != app_set_.end(); | 
| } | 
| - void AddApp(const std::string& app_id) { | 
| - if (HasApp(app_id)) | 
| + void AddApp(const AppLauncherId& app_launcher_id) { | 
| + if (HasApp(app_launcher_id)) | 
| return; | 
| - app_list_.push_back(app_id); | 
| - app_set_.insert(app_id); | 
| + app_list_.push_back(app_launcher_id.GetAsString()); | 
| + app_set_.insert(app_launcher_id.GetAsString()); | 
| } | 
| - void MaybeAddApp(const std::string& app_id, | 
| + void MaybeAddApp(const AppLauncherId& app_launcher_id, | 
| const LauncherControllerHelper* helper) { | 
| - DCHECK_NE(kPinnedAppsPlaceholder, app_id); | 
| - if (!helper->IsValidIDForCurrentUser(app_id)) | 
| + DCHECK_NE(kPinnedAppsPlaceholder, app_launcher_id.GetAsString()); | 
| + if (!helper->IsValidIDForCurrentUser(app_launcher_id.GetAsString())) | 
| return; | 
| - AddApp(app_id); | 
| + AddApp(app_launcher_id); | 
| } | 
| void MaybeAddAppFromPref(const base::DictionaryValue* app_pref, | 
| @@ -260,7 +262,7 @@ class AppTracker { | 
| return; | 
| } | 
| - MaybeAddApp(app_id, helper); | 
| + MaybeAddApp(AppLauncherId(app_id), helper); | 
| } | 
| const std::vector<std::string>& app_list() const { return app_list_; } | 
| 
stevenjb
2016/09/27 16:42:36
These should both store AppLauncherId instead of a
 
Andra Paraschiv
2016/10/03 15:53:02
Done.
 | 
| @@ -309,9 +311,9 @@ void RegisterChromeLauncherUserPrefs( | 
| registry->RegisterBooleanPref(prefs::kShowLogoutButtonInTray, false); | 
| } | 
| -base::DictionaryValue* CreateAppDict(const std::string& app_id) { | 
| +base::DictionaryValue* CreateAppDict(const AppLauncherId& app_launcher_id) { | 
| std::unique_ptr<base::DictionaryValue> app_value(new base::DictionaryValue); | 
| - app_value->SetString(kPinnedAppsPrefAppIDPath, app_id); | 
| + app_value->SetString(kPinnedAppsPrefAppIDPath, app_launcher_id.GetAsString()); | 
| return app_value.release(); | 
| } | 
| @@ -408,10 +410,10 @@ void GetAppsPinnedByPolicy(const PrefService* prefs, | 
| for (const auto& activity : activities) { | 
| const std::string arc_app_id = | 
| ArcAppListPrefs::GetAppId(arc_package, activity); | 
| - apps->MaybeAddApp(arc_app_id, helper); | 
| + apps->MaybeAddApp(AppLauncherId(arc_app_id), helper); | 
| } | 
| } else { | 
| - apps->MaybeAddApp(app_id, helper); | 
| + apps->MaybeAddApp(AppLauncherId(app_id), helper); | 
| } | 
| } | 
| } | 
| @@ -433,7 +435,7 @@ std::vector<std::string> GetPinnedAppsFromPrefsLegacy( | 
| // Check if Chrome is in either of the the preferences lists. | 
| std::unique_ptr<base::Value> chrome_app( | 
| - CreateAppDict(extension_misc::kChromeAppId)); | 
| + CreateAppDict(AppLauncherId(extension_misc::kChromeAppId))); | 
| AppTracker apps; | 
| GetAppsPinnedByPolicy(prefs, helper, &apps); | 
| @@ -443,7 +445,7 @@ std::vector<std::string> GetPinnedAppsFromPrefsLegacy( | 
| // We need to position the chrome icon relative to its place in the pinned | 
| // preference list - even if an item of that list isn't shown yet. | 
| if (i == chrome_icon_index) | 
| - apps.AddApp(extension_misc::kChromeAppId); | 
| + apps.AddApp(AppLauncherId(extension_misc::kChromeAppId)); | 
| const base::DictionaryValue* app_pref = nullptr; | 
| if (!pinned_apps->GetDictionary(i, &app_pref)) { | 
| LOG(ERROR) << "There is no dictionary for app entry."; | 
| @@ -453,7 +455,7 @@ std::vector<std::string> GetPinnedAppsFromPrefsLegacy( | 
| } | 
| // If not added yet, the chrome item will be the last item in the list. | 
| - apps.AddApp(extension_misc::kChromeAppId); | 
| + apps.AddApp(AppLauncherId(extension_misc::kChromeAppId)); | 
| return apps.app_list(); | 
| } | 
| @@ -597,8 +599,8 @@ std::vector<std::string> GetPinnedAppsFromPrefs( | 
| continue; | 
| } | 
| - pin_infos.push_back( | 
| - PinInfo(sync_peer.first, sync_peer.second->item_pin_ordinal)); | 
| + pin_infos.push_back(PinInfo(AppLauncherId(sync_peer.first), | 
| + sync_peer.second->item_pin_ordinal)); | 
| } | 
| if (first_run) { | 
| @@ -624,15 +626,17 @@ std::vector<std::string> GetPinnedAppsFromPrefs( | 
| continue; | 
| // Now move it to the front. | 
| - pin_infos.insert(pin_infos.begin(), PinInfo(app_id, front_position)); | 
| + pin_infos.insert(pin_infos.begin(), | 
| + PinInfo(AppLauncherId(app_id), front_position)); | 
| app_service->SetPinPosition(app_id, front_position); | 
| front_position = front_position.CreateBefore(); | 
| } | 
| // Now insert Chrome browser app if needed. | 
| if (!app_service->GetPinPosition(extension_misc::kChromeAppId).IsValid()) { | 
| - pin_infos.insert(pin_infos.begin(), | 
| - PinInfo(extension_misc::kChromeAppId, front_position)); | 
| + pin_infos.insert( | 
| + pin_infos.begin(), | 
| + PinInfo(AppLauncherId(extension_misc::kChromeAppId), front_position)); | 
| app_service->SetPinPosition(extension_misc::kChromeAppId, front_position); | 
| } | 
| @@ -641,7 +645,8 @@ std::vector<std::string> GetPinnedAppsFromPrefs( | 
| const syncer::StringOrdinal arc_host_position = | 
| GetLastPinPosition(helper->profile()); | 
| pin_infos.insert(pin_infos.begin(), | 
| - PinInfo(ArcSupportHost::kHostAppId, arc_host_position)); | 
| + PinInfo(AppLauncherId(ArcSupportHost::kHostAppId), | 
| + arc_host_position)); | 
| app_service->SetPinPosition(ArcSupportHost::kHostAppId, | 
| arc_host_position); | 
| } | 
| @@ -650,26 +655,30 @@ std::vector<std::string> GetPinnedAppsFromPrefs( | 
| // Convert to string array. | 
| std::vector<std::string> pins(pin_infos.size()); | 
| for (size_t i = 0; i < pin_infos.size(); ++i) | 
| - pins[i] = pin_infos[i].app_id; | 
| + pins[i] = pin_infos[i].app_launcher_id; | 
| return pins; | 
| } | 
| -void RemovePinPosition(Profile* profile, const std::string& app_id) { | 
| +void RemovePinPosition(Profile* profile, const AppLauncherId& app_launcher_id) { | 
| DCHECK(profile); | 
| - DCHECK(!app_id.empty()); | 
| + const std::string launcher_id = app_launcher_id.GetAsString(); | 
| + DCHECK(!launcher_id.empty()); | 
| app_list::AppListSyncableService* app_service = | 
| app_list::AppListSyncableServiceFactory::GetForProfile(profile); | 
| - app_service->SetPinPosition(app_id, syncer::StringOrdinal()); | 
| + app_service->SetPinPosition(launcher_id, syncer::StringOrdinal()); | 
| } | 
| -void SetPinPosition(Profile* profile, | 
| - const std::string& app_id, | 
| - const std::string& app_id_before, | 
| - const std::vector<std::string>& app_ids_after) { | 
| +void SetPinPosition( | 
| + Profile* profile, | 
| + const AppLauncherId& app_launcher_id, | 
| + const AppLauncherId& app_launcher_id_before, | 
| + const std::vector<std::unique_ptr<AppLauncherId>>& app_launcher_ids_after) { | 
| DCHECK(profile); | 
| - DCHECK(!app_id.empty()); | 
| - DCHECK_NE(app_id, app_id_before); | 
| + const std::string launcher_id = app_launcher_id.GetAsString(); | 
| + DCHECK(!launcher_id.empty()); | 
| + const std::string launcher_id_before = app_launcher_id_before.GetAsString(); | 
| + DCHECK_NE(launcher_id, launcher_id_before); | 
| app_list::AppListSyncableService* app_service = | 
| app_list::AppListSyncableServiceFactory::GetForProfile(profile); | 
| @@ -678,16 +687,19 @@ void SetPinPosition(Profile* profile, | 
| return; | 
| syncer::StringOrdinal position_before = | 
| - app_id_before.empty() ? syncer::StringOrdinal() | 
| - : app_service->GetPinPosition(app_id_before); | 
| + launcher_id_before.empty() | 
| + ? syncer::StringOrdinal() | 
| + : app_service->GetPinPosition(launcher_id_before); | 
| syncer::StringOrdinal position_after; | 
| - for (const auto& app_id_after : app_ids_after) { | 
| - DCHECK_NE(app_id_after, app_id); | 
| - DCHECK_NE(app_id_after, app_id_before); | 
| - syncer::StringOrdinal position = app_service->GetPinPosition(app_id_after); | 
| + for (const auto& app_launcher_id_after : app_launcher_ids_after) { | 
| + const std::string launcher_id_after = app_launcher_id_after->GetAsString(); | 
| + DCHECK_NE(launcher_id_after, launcher_id); | 
| + DCHECK_NE(launcher_id_after, launcher_id_before); | 
| + syncer::StringOrdinal position = | 
| + app_service->GetPinPosition(launcher_id_after); | 
| DCHECK(position.IsValid()); | 
| if (!position.IsValid()) { | 
| - LOG(ERROR) << "Sync pin position was not found for " << app_id_after; | 
| + LOG(ERROR) << "Sync pin position was not found for " << launcher_id_after; | 
| continue; | 
| } | 
| if (!position_before.IsValid() || !position.Equals(position_before)) { | 
| @@ -705,7 +717,20 @@ void SetPinPosition(Profile* profile, | 
| pin_position = position_after.CreateBefore(); | 
| else | 
| pin_position = syncer::StringOrdinal::CreateInitialOrdinal(); | 
| - app_service->SetPinPosition(app_id, pin_position); | 
| + app_service->SetPinPosition(launcher_id, pin_position); | 
| +} | 
| + | 
| +AppLauncherId::AppLauncherId(const std::string& app_id) | 
| + : app_launcher_id_(app_id) {} | 
| + | 
| +AppLauncherId::AppLauncherId(const std::string& app_id, | 
| + const std::string& launch_id) | 
| + : app_launcher_id_(app_id + launch_id) {} | 
| + | 
| +AppLauncherId::~AppLauncherId() {} | 
| + | 
| +bool AppLauncherId::operator==(const AppLauncherId& app_launcher_id) const { | 
| + return app_launcher_id.GetAsString() == app_launcher_id_; | 
| } | 
| 
stevenjb
2016/09/27 16:42:36
These should match the order in the header (i.e be
 
Andra Paraschiv
2016/10/03 15:53:02
Done.
 | 
| } // namespace launcher |