diff options
author | cpu@google.com <cpu@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-10-17 18:05:54 +0000 |
---|---|---|
committer | cpu@google.com <cpu@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-10-17 18:05:54 +0000 |
commit | 09da32d543461c90fcf3490966e0c4a670b9a2a8 (patch) | |
tree | 9503fe2d5a63b14bab3b5f00d6119770ec2a99d8 /chrome/browser/first_run.cc | |
parent | 937bcde53a86ea06ac8379e882de339ed95e3897 (diff) | |
download | chromium_src-09da32d543461c90fcf3490966e0c4a670b9a2a8.zip chromium_src-09da32d543461c90fcf3490966e0c4a670b9a2a8.tar.gz chromium_src-09da32d543461c90fcf3490966e0c4a670b9a2a8.tar.bz2 |
Add processing for a master profile json file on first run. Allows:
- set home page / show home button
- show bookmarks bar
Review URL: http://codereview.chromium.org/7369
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@3542 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/first_run.cc')
-rw-r--r-- | chrome/browser/first_run.cc | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/chrome/browser/first_run.cc b/chrome/browser/first_run.cc index 96ca07d..f0e7dd2 100644 --- a/chrome/browser/first_run.cc +++ b/chrome/browser/first_run.cc @@ -16,11 +16,13 @@ #include "base/process_util.h" #include "base/string_util.h" #include "chrome/app/result_codes.h" +#include "chrome/common/chrome_constants.h" #include "chrome/common/chrome_switches.h" #include "chrome/browser/browser_process.h" #include "chrome/browser/hang_monitor/hung_window_detector.h" #include "chrome/browser/importer/importer.h" #include "chrome/browser/profile.h" +#include "chrome/browser/profile_manager.h" #include "chrome/browser/views/first_run_view.h" #include "chrome/common/chrome_constants.h" #include "chrome/common/chrome_paths.h" @@ -38,6 +40,10 @@ const wchar_t kSentinelFile[] = L"First Run"; const wchar_t kChromeUpgradeExe[] = L"new_chrome.exe"; const wchar_t kChromeBackupExe[] = L"old_chrome.exe"; +// This is the default name for the master preferences file used to pre-set +// values in the user profile at first run. +const wchar_t kDefaultMasterPrefs[] = L"master_preferences"; + // Gives the full path to the sentinel file. The file might not exist. bool GetFirstRunSentinelFilePath(std::wstring* path) { std::wstring first_run_sentinel; @@ -62,6 +68,19 @@ bool GetBackupChromeFile(std::wstring* path) { return true; } +std::wstring GetDefaultPrefFilePath(bool create_profile_dir, + const std::wstring& user_data_dir) { + std::wstring default_pref_dir = + ProfileManager::GetDefaultProfileDir(user_data_dir); + if (create_profile_dir) { + if (!file_util::PathExists(default_pref_dir)) { + if (!file_util::CreateDirectory(default_pref_dir)) + return std::wstring(); + } + } + return ProfileManager::GetDefaultProfilePath(default_pref_dir); +} + } // namespace bool FirstRun::IsChromeFirstRun() { @@ -132,6 +151,38 @@ bool FirstRun::CreateSentinel() { return true; } +FirstRun::MasterPrefResult FirstRun::ProcessMasterPreferences( + const std::wstring& user_data_dir, + const std::wstring& master_prefs_path) { + DCHECK(!user_data_dir.empty()); + std::wstring master_prefs; + if (master_prefs_path.empty()) { + // The default location of the master prefs is next to the chrome exe. + std::wstring master_path; + if (!PathService::Get(base::DIR_EXE, &master_path)) + return MASTER_PROFILE_ERROR; + file_util::AppendToPath(&master_path, kDefaultMasterPrefs); + if (!file_util::PathExists(master_path)) + return MASTER_PROFILE_NOT_FOUND; + master_prefs = master_path; + } else { + master_prefs = master_prefs_path; + } + + std::wstring user_prefs = GetDefaultPrefFilePath(true, user_data_dir); + if (user_prefs.empty()) + return MASTER_PROFILE_ERROR; + + // The master prefs are regular prefs so we can just copy the file + // to the default place and they just work. + if (!file_util::CopyFile(master_prefs, user_prefs)) + return MASTER_PROFILE_ERROR; + + // TODO (cpu): Process the 'distribution' dictionary and return the + // appropriate values. + return MASTER_PROFILE_NO_FIRST_RUN_UI; +} + bool Upgrade::SwapNewChromeExeIfPresent() { std::wstring new_chrome_exe; if (!GetNewerChromeFile(&new_chrome_exe)) |