Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 #include <set> | 5 #include <set> |
| 6 | 6 |
| 7 #include "chrome/browser/profiles/profile_manager.h" | 7 #include "chrome/browser/profiles/profile_manager.h" |
| 8 | 8 |
| 9 #include "base/command_line.h" | 9 #include "base/command_line.h" |
| 10 #include "base/file_path.h" | 10 #include "base/file_path.h" |
| (...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 50 using content::BrowserThread; | 50 using content::BrowserThread; |
| 51 | 51 |
| 52 namespace { | 52 namespace { |
| 53 | 53 |
| 54 // Profiles that should be deleted on shutdown. | 54 // Profiles that should be deleted on shutdown. |
| 55 std::vector<FilePath>& ProfilesToDelete() { | 55 std::vector<FilePath>& ProfilesToDelete() { |
| 56 CR_DEFINE_STATIC_LOCAL(std::vector<FilePath>, profiles_to_delete, ()); | 56 CR_DEFINE_STATIC_LOCAL(std::vector<FilePath>, profiles_to_delete, ()); |
| 57 return profiles_to_delete; | 57 return profiles_to_delete; |
| 58 } | 58 } |
| 59 | 59 |
| 60 // Checks if any user prefs for |profile| have default values. | |
| 61 bool HasAnyDefaultUserPrefs(Profile* profile){ | |
| 62 const PrefService::Preference* avatar_index = | |
| 63 profile->GetPrefs()->FindPreference(prefs::kProfileAvatarIndex); | |
| 64 DCHECK(avatar_index); | |
| 65 const PrefService::Preference* profile_name = | |
| 66 profile->GetPrefs()->FindPreference(prefs::kProfileName); | |
| 67 DCHECK(profile_name); | |
| 68 return avatar_index->IsDefaultValue() || | |
| 69 profile_name->IsDefaultValue(); | |
| 70 } | |
| 71 | |
| 60 // Simple task to log the size of the current profile. | 72 // Simple task to log the size of the current profile. |
| 61 class ProfileSizeTask : public Task { | 73 class ProfileSizeTask : public Task { |
| 62 public: | 74 public: |
| 63 explicit ProfileSizeTask(Profile* profile); | 75 explicit ProfileSizeTask(Profile* profile); |
| 64 virtual ~ProfileSizeTask() {} | 76 virtual ~ProfileSizeTask() {} |
| 65 | 77 |
| 66 virtual void Run(); | 78 virtual void Run(); |
| 67 private: | 79 private: |
| 68 FilePath path_; | 80 FilePath path_; |
| 69 int extension_count_; | 81 int extension_count_; |
| (...skipping 392 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 462 DCHECK(local_state); | 474 DCHECK(local_state); |
| 463 // Only keep track of profiles that we are managing; tests may create others. | 475 // Only keep track of profiles that we are managing; tests may create others. |
| 464 if (profiles_info_.find(last_active->GetPath()) != profiles_info_.end()) { | 476 if (profiles_info_.find(last_active->GetPath()) != profiles_info_.end()) { |
| 465 local_state->SetString(prefs::kProfileLastUsed, | 477 local_state->SetString(prefs::kProfileLastUsed, |
| 466 last_active->GetPath().BaseName().MaybeAsASCII()); | 478 last_active->GetPath().BaseName().MaybeAsASCII()); |
| 467 } | 479 } |
| 468 } | 480 } |
| 469 | 481 |
| 470 void ProfileManager::DoFinalInit(Profile* profile, bool go_off_the_record) { | 482 void ProfileManager::DoFinalInit(Profile* profile, bool go_off_the_record) { |
| 471 DoFinalInitForServices(profile, go_off_the_record); | 483 DoFinalInitForServices(profile, go_off_the_record); |
| 484 InitProfileUserPrefs(profile); | |
| 472 AddProfileToCache(profile); | 485 AddProfileToCache(profile); |
| 473 DoFinalInitLogging(profile); | 486 DoFinalInitLogging(profile); |
| 474 } | 487 } |
| 475 | 488 |
| 476 void ProfileManager::DoFinalInitForServices(Profile* profile, | 489 void ProfileManager::DoFinalInitForServices(Profile* profile, |
| 477 bool go_off_the_record) { | 490 bool go_off_the_record) { |
| 478 const CommandLine& command_line = *CommandLine::ForCurrentProcess(); | 491 const CommandLine& command_line = *CommandLine::ForCurrentProcess(); |
| 479 profile->InitExtensions(!go_off_the_record); | 492 profile->InitExtensions(!go_off_the_record); |
| 480 if (!command_line.HasSwitch(switches::kDisableWebResources)) | 493 if (!command_line.HasSwitch(switches::kDisableWebResources)) |
| 481 profile->InitPromoResources(); | 494 profile->InitPromoResources(); |
| (...skipping 131 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 613 ProfileInfoCache& cache = GetProfileInfoCache(); | 626 ProfileInfoCache& cache = GetProfileInfoCache(); |
| 614 if (profile->GetPath().DirName() != cache.GetUserDataDir()) | 627 if (profile->GetPath().DirName() != cache.GetUserDataDir()) |
| 615 return; | 628 return; |
| 616 | 629 |
| 617 if (cache.GetIndexOfProfileWithPath(profile->GetPath()) != std::string::npos) | 630 if (cache.GetIndexOfProfileWithPath(profile->GetPath()) != std::string::npos) |
| 618 return; | 631 return; |
| 619 | 632 |
| 620 string16 username = UTF8ToUTF16(profile->GetPrefs()->GetString( | 633 string16 username = UTF8ToUTF16(profile->GetPrefs()->GetString( |
| 621 prefs::kGoogleServicesUsername)); | 634 prefs::kGoogleServicesUsername)); |
| 622 | 635 |
| 623 if (profile->GetPath() == GetDefaultProfileDir(cache.GetUserDataDir())) { | 636 string16 profile_name = UTF8ToUTF16(profile->GetPrefs()->GetString( |
|
sail
2011/12/02 19:07:10
can you add a comment to explain why you're doing
jwd
2011/12/02 21:10:16
Done.
| |
| 624 cache.AddProfileToCache( | 637 prefs::kProfileName)); |
| 625 profile->GetPath(), | 638 |
| 626 l10n_util::GetStringUTF16(IDS_DEFAULT_PROFILE_NAME), username, 0); | 639 size_t icon_index = profile->GetPrefs()->GetInteger( |
| 627 } else { | 640 prefs::kProfileAvatarIndex); |
| 628 size_t icon_index = cache.ChooseAvatarIconIndexForNewProfile(); | 641 |
| 629 cache.AddProfileToCache(profile->GetPath(), | 642 cache.AddProfileToCache(profile->GetPath(), |
| 630 cache.ChooseNameForNewProfile(icon_index), | 643 profile_name, |
| 631 username, | 644 username, |
| 632 icon_index); | 645 icon_index); |
| 646 } | |
| 647 | |
| 648 void ProfileManager::InitProfileUserPrefs(Profile* profile) { | |
| 649 ProfileInfoCache& cache = GetProfileInfoCache(); | |
| 650 | |
| 651 if (profile->GetPath().DirName() != cache.GetUserDataDir()) | |
| 652 return; | |
| 653 | |
| 654 if (HasAnyDefaultUserPrefs(profile)) { | |
|
sail
2011/12/02 19:07:10
can you add a comment to explain why you're doing
jwd
2011/12/02 21:10:16
Done.
| |
| 655 size_t profile_cache_index = | |
| 656 cache.GetIndexOfProfileWithPath(profile->GetPath()); | |
| 657 if (profile_cache_index != std::string::npos) { | |
| 658 profile->GetPrefs()->SetInteger(prefs::kProfileAvatarIndex, | |
| 659 cache.GetAvatarIconIndexOfProfileAtIndex(profile_cache_index)); | |
| 660 profile->GetPrefs()->SetString(prefs::kProfileName, | |
| 661 UTF16ToUTF8(cache.GetNameOfProfileAtIndex(profile_cache_index))); | |
| 662 } else if (profile->GetPath() == | |
| 663 GetDefaultProfileDir(cache.GetUserDataDir())) { | |
| 664 profile->GetPrefs()->SetInteger(prefs::kProfileAvatarIndex, 0); | |
| 665 profile->GetPrefs()->SetString(prefs::kProfileName, | |
| 666 l10n_util::GetStringUTF8(IDS_DEFAULT_PROFILE_NAME)); | |
| 667 } else { | |
| 668 size_t icon_index = cache.ChooseAvatarIconIndexForNewProfile(); | |
| 669 profile->GetPrefs()->SetInteger(prefs::kProfileAvatarIndex, icon_index); | |
| 670 profile->GetPrefs()->SetString( | |
| 671 prefs::kProfileName, | |
| 672 UTF16ToUTF8(cache.ChooseNameForNewProfile(icon_index))); | |
| 673 } | |
| 633 } | 674 } |
| 634 } | 675 } |
| 635 | 676 |
| 636 bool ProfileManager::ShouldGoOffTheRecord() { | 677 bool ProfileManager::ShouldGoOffTheRecord() { |
| 637 bool go_off_the_record = false; | 678 bool go_off_the_record = false; |
| 638 #if defined(OS_CHROMEOS) | 679 #if defined(OS_CHROMEOS) |
| 639 const CommandLine& command_line = *CommandLine::ForCurrentProcess(); | 680 const CommandLine& command_line = *CommandLine::ForCurrentProcess(); |
| 640 if (!logged_in_ && | 681 if (!logged_in_ && |
| 641 (!command_line.HasSwitch(switches::kTestType) || | 682 (!command_line.HasSwitch(switches::kTestType) || |
| 642 command_line.HasSwitch(switches::kLoginProfile))) { | 683 command_line.HasSwitch(switches::kLoginProfile))) { |
| (...skipping 71 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 714 RegisterProfile(profile, true); | 755 RegisterProfile(profile, true); |
| 715 if (add_to_cache) | 756 if (add_to_cache) |
| 716 AddProfileToCache(profile); | 757 AddProfileToCache(profile); |
| 717 } | 758 } |
| 718 | 759 |
| 719 #if defined(OS_WIN) | 760 #if defined(OS_WIN) |
| 720 void ProfileManager::RemoveProfileShortcutManagerForTesting() { | 761 void ProfileManager::RemoveProfileShortcutManagerForTesting() { |
| 721 profile_info_cache_->RemoveObserver(profile_shortcut_manager_.get()); | 762 profile_info_cache_->RemoveObserver(profile_shortcut_manager_.get()); |
| 722 } | 763 } |
| 723 #endif | 764 #endif |
| OLD | NEW |