Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(30)

Unified Diff: chrome/app/chrome_main_delegate.cc

Issue 174253002: Initialize chrome::DIR_USER_DATA early on for service processes, etc. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Use dynamic_annotations_win64 for common_constants_win64. Created 6 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | chrome/browser/chrome_browser_main.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/app/chrome_main_delegate.cc
diff --git a/chrome/app/chrome_main_delegate.cc b/chrome/app/chrome_main_delegate.cc
index 1d79c25c85aa9fd031bbc2c6e1815775e41e3cd0..26ef191816f50a4e3031549e0f1ba572076b8413 100644
--- a/chrome/app/chrome_main_delegate.cc
+++ b/chrome/app/chrome_main_delegate.cc
@@ -14,17 +14,20 @@
#include "base/path_service.h"
#include "base/process/memory.h"
#include "base/process/process_handle.h"
+#include "base/strings/string_util.h"
#include "build/build_config.h"
#include "chrome/browser/chrome_content_browser_client.h"
#include "chrome/browser/defaults.h"
#include "chrome/common/chrome_constants.h"
#include "chrome/common/chrome_content_client.h"
#include "chrome/common/chrome_paths.h"
+#include "chrome/common/chrome_paths_internal.h"
#include "chrome/common/chrome_switches.h"
#include "chrome/common/chrome_version_info.h"
#include "chrome/common/crash_keys.h"
#include "chrome/common/logging_chrome.h"
#include "chrome/common/profiling.h"
+#include "chrome/common/switch_utils.h"
#include "chrome/common/url_constants.h"
#include "chrome/plugin/chrome_content_plugin_client.h"
#include "chrome/renderer/chrome_content_renderer_client.h"
@@ -96,6 +99,14 @@
#include "components/breakpad/app/breakpad_linux.h"
#endif
+#if defined(OS_LINUX)
+#include "base/environment.h"
+#endif
+
+#if defined(OS_MACOSX) || defined(OS_WIN)
+#include "chrome/browser/policy/policy_path_parser.h"
+#endif
+
#if !defined(CHROME_MULTIPLE_DLL_CHILD)
base::LazyInstance<chrome::ChromeContentBrowserClient>
g_chrome_content_browser_client = LAZY_INSTANCE_INITIALIZER;
@@ -310,6 +321,50 @@ struct MainFunction {
int (*function)(const content::MainFunctionParams&);
};
+// Initializes the user data dir. Must be called before InitializeLocalState().
+void InitializeUserDataDir() {
+ CommandLine* command_line = CommandLine::ForCurrentProcess();
+ base::FilePath user_data_dir =
+ command_line->GetSwitchValuePath(switches::kUserDataDir);
+ std::string process_type =
+ command_line->GetSwitchValueASCII(switches::kProcessType);
+
+#if defined(OS_LINUX)
+ // On Linux, Chrome does not support running multiple copies under different
+ // DISPLAYs, so the profile directory can be specified in the environment to
+ // support the virtual desktop use-case.
+ if (user_data_dir.empty()) {
+ std::string user_data_dir_string;
+ scoped_ptr<base::Environment> environment(base::Environment::Create());
+ if (environment->GetVar("CHROME_USER_DATA_DIR", &user_data_dir_string) &&
+ IsStringUTF8(user_data_dir_string)) {
+ user_data_dir = base::FilePath::FromUTF8Unsafe(user_data_dir_string);
+ }
+ }
+#endif
+#if defined(OS_MACOSX) || defined(OS_WIN)
+ policy::path_parser::CheckUserDataDirPolicy(&user_data_dir);
+#endif
+
+ const bool specified_directory_was_invalid = !user_data_dir.empty() &&
+ !PathService::OverrideAndCreateIfNeeded(chrome::DIR_USER_DATA,
+ user_data_dir, chrome::ProcessNeedsProfileDir(process_type));
+ // Save inaccessible or invalid paths so the user may be prompted later.
+ if (specified_directory_was_invalid)
+ chrome::SetInvalidSpecifiedUserDataDir(user_data_dir);
+
+ // Getting the user data directory can fail if the directory isn't creatable.
+ // ProcessSingleton needs a real user data directory on Mac/Linux, so it's
+ // better to fail here than fail mysteriously elsewhere.
+ CHECK(PathService::Get(chrome::DIR_USER_DATA, &user_data_dir))
+ << "Must be able to get user data directory!";
+
+ // Append the fallback user data directory to the commandline. Otherwise,
+ // child or service processes will attempt to use the invalid directory.
+ if (specified_directory_was_invalid)
+ command_line->AppendSwitchPath(switches::kUserDataDir, user_data_dir);
+}
+
} // namespace
ChromeMainDelegate::ChromeMainDelegate() {
@@ -578,6 +633,9 @@ void ChromeMainDelegate::PreSandboxStartup() {
child_process_logging::Init();
#endif
+ // Initialize the user data dir for service processes, logging, etc.
+ InitializeUserDataDir();
+
stats_counter_timer_.reset(new base::StatsCounterTimer("Chrome.Init"));
startup_timer_.reset(new base::StatsScope<base::StatsCounterTimer>
(*stats_counter_timer_));
« no previous file with comments | « no previous file | chrome/browser/chrome_browser_main.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698