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

Unified Diff: chrome/common/chrome_paths_linux.cc

Issue 28239: Reverting 10555. (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: Created 11 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/common/common.scons » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/common/chrome_paths_linux.cc
===================================================================
--- chrome/common/chrome_paths_linux.cc (revision 10559)
+++ chrome/common/chrome_paths_linux.cc (working copy)
@@ -5,53 +5,31 @@
#include "chrome/common/chrome_paths_internal.h"
#include <glib.h>
-#include <stdlib.h>
-
#include "base/file_path.h"
#include "base/logging.h"
-#include "base/path_service.h"
-#include "chrome/third_party/xdg_user_dirs/xdg_user_dir_lookup.h"
namespace {
-FilePath GetHomeDir() {
- const char *home_dir = getenv("HOME");
-
- if (home_dir && home_dir[0])
- return FilePath(home_dir);
-
- home_dir = g_get_home_dir();
- if (home_dir && home_dir[0])
- return FilePath(home_dir);
-
- FilePath rv;
- if (PathService::Get(base::DIR_TEMP, &rv))
- return rv;
-
- /* last resort */
- return FilePath("/tmp/");
-}
-
-// Wrapper around xdg_user_dir_lookup() from
-// src/chrome/third_party/xdg-user-dirs
-FilePath GetXDGUserDirectory(const char* env_name, const char* fallback_dir) {
- char* xdg_dir = xdg_user_dir_lookup(env_name);
- if (xdg_dir) {
- FilePath rv(xdg_dir);
- free(xdg_dir);
- return rv;
- }
- return GetHomeDir().Append(fallback_dir);
-}
-
// |env_name| is the name of an environment variable that we want to use to get
// a directory path. |fallback_dir| is the directory relative to $HOME that we
// use if |env_name| cannot be found or is empty. |fallback_dir| may be NULL.
-FilePath GetXDGDirectory(const char* env_name, const char* fallback_dir) {
- const char* env_value = getenv(env_name);
- if (env_value && env_value[0])
- return FilePath(env_value);
- return GetHomeDir().Append(fallback_dir);
+// TODO(thestig): Don't use g_getenv() here because most of the time XDG
+// environment variables won't actually be loaded.
+FilePath GetStandardDirectory(const char* env_name, const char* fallback_dir) {
+ FilePath rv;
+ const char* env_value = g_getenv(env_name);
+ if (env_value && env_value[0]) {
+ rv = FilePath(env_value);
+ } else {
+ const char* home_dir = g_getenv("HOME");
+ if (!home_dir)
+ home_dir = g_get_home_dir();
+ rv = FilePath(home_dir);
+ if (fallback_dir)
+ rv = rv.Append(fallback_dir);
+ }
+
+ return rv;
}
} // namespace
@@ -64,7 +42,7 @@
// ~/.config/google-chrome/ for official builds.
// (This also helps us sidestep issues with other apps grabbing ~/.chromium .)
bool GetDefaultUserDataDirectory(FilePath* result) {
- FilePath config_dir(GetXDGDirectory("XDG_CONFIG_HOME", ".config"));
+ FilePath config_dir = GetStandardDirectory("XDG_CONFIG_HOME", ".config");
#if defined(GOOGLE_CHROME_BUILD)
*result = config_dir.Append("google-chrome");
#else
@@ -74,12 +52,12 @@
}
bool GetUserDocumentsDirectory(FilePath* result) {
- *result = GetXDGUserDirectory("DOCUMENTS", "Documents");
+ *result = GetStandardDirectory("XDG_DOCUMENTS_DIR", "Documents");
return true;
}
bool GetUserDesktop(FilePath* result) {
- *result = GetXDGUserDirectory("DESKTOP", "Desktop");
+ *result = GetStandardDirectory("XDG_DESKTOP_DIR", "Desktop");
return true;
}
« no previous file with comments | « no previous file | chrome/common/common.scons » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698