summaryrefslogtreecommitdiffstats
path: root/chrome/browser
diff options
context:
space:
mode:
Diffstat (limited to 'chrome/browser')
-rw-r--r--chrome/browser/first_run.h6
-rw-r--r--chrome/browser/first_run_win.cc31
2 files changed, 32 insertions, 5 deletions
diff --git a/chrome/browser/first_run.h b/chrome/browser/first_run.h
index 910edf56..d8a5cfd 100644
--- a/chrome/browser/first_run.h
+++ b/chrome/browser/first_run.h
@@ -106,6 +106,12 @@ class FirstRun {
// Import browser items in this process. The browser and the items to
// import are encoded int the command line.
static int ImportFromBrowser(Profile* profile, const CommandLine& cmdline);
+ // Imports settings in a separate process. It is the implementation of the
+ // public version.
+ static bool ImportSettings(Profile* profile, int browser_type,
+ int items_to_import,
+ const std::wstring& import_path,
+ gfx::NativeView parent_window);
#endif // OS_WIN
// This class is for scoping purposes.
DISALLOW_IMPLICIT_CONSTRUCTORS(FirstRun);
diff --git a/chrome/browser/first_run_win.cc b/chrome/browser/first_run_win.cc
index e4959e0..0e0925d 100644
--- a/chrome/browser/first_run_win.cc
+++ b/chrome/browser/first_run_win.cc
@@ -355,13 +355,18 @@ bool FirstRun::ProcessMasterPreferences(const FilePath& user_data_dir,
value)
import_items += importer::HOME_PAGE;
- if (import_items) {
+ std::wstring import_bookmarks_path;
+ installer_util::GetDistroStringPreference(prefs.get(),
+ installer_util::master_preferences::kDistroImportBookmarksFromFilePref,
+ &import_bookmarks_path);
+
+ if (import_items || !import_bookmarks_path.empty()) {
// There is something to import from the default browser. This launches
// the importer process and blocks until done or until it fails.
scoped_refptr<ImporterHost> importer_host = new ImporterHost();
if (!FirstRun::ImportSettings(NULL,
importer_host->GetSourceProfileInfoAt(0).browser_type,
- import_items, NULL)) {
+ import_items, import_bookmarks_path, NULL)) {
LOG(WARNING) << "silent import failed";
}
}
@@ -625,7 +630,9 @@ bool DecodeImportParams(const std::wstring& encoded,
} // namespace
bool FirstRun::ImportSettings(Profile* profile, int browser_type,
- int items_to_import, HWND parent_window) {
+ int items_to_import,
+ const std::wstring& import_bookmarks_path,
+ HWND parent_window) {
const CommandLine& cmdline = *CommandLine::ForCurrentProcess();
CommandLine import_cmd(cmdline.GetProgram());
// Propagate user data directory switch.
@@ -642,8 +649,15 @@ bool FirstRun::ImportSettings(Profile* profile, int browser_type,
switches::kLang,
ASCIIToWide(g_browser_process->GetApplicationLocale()));
- import_cmd.CommandLine::AppendSwitchWithValue(switches::kImport,
- EncodeImportParams(browser_type, items_to_import, parent_window));
+ if (items_to_import) {
+ import_cmd.CommandLine::AppendSwitchWithValue(switches::kImport,
+ EncodeImportParams(browser_type, items_to_import, parent_window));
+ }
+
+ if (!import_bookmarks_path.empty()) {
+ import_cmd.CommandLine::AppendSwitchWithValue(
+ switches::kImportFromFile, import_bookmarks_path.c_str());
+ }
if (cmdline.HasSwitch(switches::kChromeFrame)) {
import_cmd.AppendSwitch(switches::kChromeFrame);
@@ -672,6 +686,13 @@ bool FirstRun::ImportSettings(Profile* profile, int browser_type,
return (import_runner.exit_code() == ResultCodes::NORMAL_EXIT);
}
+bool FirstRun::ImportSettings(Profile* profile, int browser_type,
+ int items_to_import,
+ HWND parent_window) {
+ return ImportSettings(profile, browser_type, items_to_import,
+ std::wstring(), parent_window);
+}
+
int FirstRun::ImportFromFile(Profile* profile, const CommandLine& cmdline) {
std::wstring file_path = cmdline.GetSwitchValue(switches::kImportFromFile);
if (file_path.empty()) {