summaryrefslogtreecommitdiffstats
path: root/chrome/browser/first_run.cc
diff options
context:
space:
mode:
authorcpu@google.com <cpu@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-10-17 18:05:54 +0000
committercpu@google.com <cpu@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-10-17 18:05:54 +0000
commit09da32d543461c90fcf3490966e0c4a670b9a2a8 (patch)
tree9503fe2d5a63b14bab3b5f00d6119770ec2a99d8 /chrome/browser/first_run.cc
parent937bcde53a86ea06ac8379e882de339ed95e3897 (diff)
downloadchromium_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.cc51
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))