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

Unified Diff: chrome/browser/profiles/profiles_state.cc

Issue 171523004: Stop using the old-style profile names when using --new-profile-management (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: moved new tests behind no-android/no-cros ifdef Created 6 years, 10 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/profiles/profiles_state.cc
diff --git a/chrome/browser/profiles/profiles_state.cc b/chrome/browser/profiles/profiles_state.cc
index 488964e1de16c883d3f3fcaea60e7d42d04768bb..cfbf333812973f3027bb6287ee4f18abc4e435db 100644
--- a/chrome/browser/profiles/profiles_state.cc
+++ b/chrome/browser/profiles/profiles_state.cc
@@ -4,6 +4,8 @@
#include "chrome/browser/profiles/profiles_state.h"
+#include <stdio.h>
+
#include "base/files/file_path.h"
#include "base/prefs/pref_registry_simple.h"
#include "base/prefs/pref_service.h"
@@ -50,20 +52,42 @@ void RegisterPrefs(PrefRegistrySimple* registry) {
registry->RegisterListPref(prefs::kProfilesLastActive);
}
-base::string16 GetActiveProfileDisplayName(Browser* browser) {
- base::string16 profile_name;
- Profile* profile = browser->profile();
+base::string16 GetAvatarNameForProfile(Profile* profile) {
+ base::string16 display_name;
if (profile->IsGuestSession()) {
- profile_name = l10n_util::GetStringUTF16(IDS_GUEST_PROFILE_NAME);
+ display_name = l10n_util::GetStringUTF16(IDS_GUEST_PROFILE_NAME);
} else {
ProfileInfoCache& cache =
g_browser_process->profile_manager()->GetProfileInfoCache();
size_t index = cache.GetIndexOfProfileWithPath(profile->GetPath());
- if (index != std::string::npos)
- profile_name = cache.GetNameOfProfileAtIndex(index);
+
+ if (index == std::string::npos)
+ return l10n_util::GetStringUTF16(IDS_SINGLE_PROFILE_DISPLAY_NAME);
+
+ // Using the --new-profile-management flag, there's a couple of rules
+ // about what the avatar button displays. If there's a single, local
+ // profile, with a default name (i.e. of the form Person %d), it should
+ // display IDS_SINGLE_PROFILE_DISPLAY_NAME. If this is a signed in profile,
+ // or the user has edited the profile name, or there are multiple profiles,
+ // it will return the actual name of the profile.
+ base::string16 profile_name = cache.GetNameOfProfileAtIndex(index);
+ std::string default_name_format = l10n_util::GetStringFUTF8(
+ IDS_NEW_NUMBERED_PROFILE_NAME, base::string16()) + "%d";
+ int generic_profile_number; // Unused. Just a placeholder for sscanf.
+ int assignments = sscanf(base::UTF16ToUTF8(profile_name).c_str(),
+ default_name_format.c_str(),
+ &generic_profile_number);
+ bool has_default_name = (assignments == 1);
+
+ if (cache.GetNumberOfProfiles() == 1 && has_default_name &&
+ cache.GetUserNameOfProfileAtIndex(index).empty()) {
+ display_name = l10n_util::GetStringUTF16(IDS_SINGLE_PROFILE_DISPLAY_NAME);
+ } else {
+ display_name = profile_name;
+ }
}
- return profile_name;
+ return display_name;
}
void UpdateProfileName(Profile* profile,
« no previous file with comments | « chrome/browser/profiles/profiles_state.h ('k') | chrome/browser/ui/cocoa/browser/avatar_button_controller.mm » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698