OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef CHROME_BROWSER_PROFILES_PROFILES_STATE_H_ | 5 #ifndef CHROME_BROWSER_PROFILES_PROFILES_STATE_H_ |
6 #define CHROME_BROWSER_PROFILES_PROFILES_STATE_H_ | 6 #define CHROME_BROWSER_PROFILES_PROFILES_STATE_H_ |
7 | 7 |
8 #include <vector> | 8 #include <vector> |
9 #include "base/strings/string16.h" | 9 #include "base/strings/string16.h" |
10 | 10 |
11 class Browser; | 11 class Browser; |
12 class PrefRegistrySimple; | 12 class PrefRegistrySimple; |
13 class Profile; | 13 class Profile; |
14 namespace base { class FilePath; } | 14 namespace base { class FilePath; } |
| 15 namespace user_prefs { class PrefRegistrySyncable; } |
15 | 16 |
16 namespace profiles { | 17 namespace profiles { |
17 | 18 |
18 // Checks if multiple profiles is enabled. | 19 // Checks if multiple profiles is enabled. |
19 bool IsMultipleProfilesEnabled(); | 20 bool IsMultipleProfilesEnabled(); |
20 | 21 |
21 // Returns the path to the default profile directory, based on the given | 22 // Returns the path to the default profile directory, based on the given |
22 // user data directory. | 23 // user data directory. |
23 base::FilePath GetDefaultProfileDir(const base::FilePath& user_data_dir); | 24 base::FilePath GetDefaultProfileDir(const base::FilePath& user_data_dir); |
24 | 25 |
25 // Register multi-profile related preferences in Local State. | 26 // Register multi-profile related preferences in Local State. |
26 void RegisterPrefs(PrefRegistrySimple* registry); | 27 void RegisterPrefs(PrefRegistrySimple* registry); |
27 | 28 |
| 29 // Register per-profile tutorial preferences. |
| 30 void RegisterTutorialPrefs(user_prefs::PrefRegistrySyncable* registry); |
| 31 |
28 // Returns the display name of the active on-the-record profile (or guest) | 32 // Returns the display name of the active on-the-record profile (or guest) |
29 // used in the avatar button. If there is only one local profile present, it | 33 // used in the avatar button. If there is only one local profile present, it |
30 // will return IDS_SINGLE_PROFILE_DISPLAY_NAME, unless the profile has a | 34 // will return IDS_SINGLE_PROFILE_DISPLAY_NAME, unless the profile has a |
31 // user entered custom name. | 35 // user entered custom name. |
32 base::string16 GetAvatarNameForProfile(Profile* profile); | 36 base::string16 GetAvatarNameForProfile(Profile* profile); |
33 | 37 |
34 // Update the name of |profile| to |new_profile_name|. This updates the | 38 // Update the name of |profile| to |new_profile_name|. This updates the |
35 // profile preferences, which triggers an update in the ProfileInfoCache. | 39 // profile preferences, which triggers an update in the ProfileInfoCache. |
36 void UpdateProfileName(Profile* profile, | 40 void UpdateProfileName(Profile* profile, |
37 const base::string16& new_profile_name); | 41 const base::string16& new_profile_name); |
38 | 42 |
39 // Returns the list of secondary accounts for a specific |profile|, which is | 43 // Returns the list of secondary accounts for a specific |profile|, which is |
40 // all the email addresses associated with the profile that are not equal to | 44 // all the email addresses associated with the profile that are not equal to |
41 // the |primary_account|. | 45 // the |primary_account|. |
42 std::vector<std::string> GetSecondaryAccountsForProfile( | 46 std::vector<std::string> GetSecondaryAccountsForProfile( |
43 Profile* profile, | 47 Profile* profile, |
44 const std::string& primary_account); | 48 const std::string& primary_account); |
45 | 49 |
46 // Returns whether the |browser|'s profile is a non-incognito or guest profile. | 50 // Returns whether the |browser|'s profile is a non-incognito or guest profile. |
47 // The distinction is needed because guest profiles are implemented as | 51 // The distinction is needed because guest profiles are implemented as |
48 // incognito profiles. | 52 // incognito profiles. |
49 bool IsRegularOrGuestSession(Browser* browser); | 53 bool IsRegularOrGuestSession(Browser* browser); |
50 | 54 |
51 } // namespace profiles | 55 } // namespace profiles |
52 | 56 |
53 #endif // CHROME_BROWSER_PROFILES_PROFILES_STATE_H_ | 57 #endif // CHROME_BROWSER_PROFILES_PROFILES_STATE_H_ |
OLD | NEW |