summaryrefslogtreecommitdiff
path: root/libs/ardour/filesystem_paths.cc
diff options
context:
space:
mode:
authorJohn Emmas <johne53@tiscali.co.uk>2014-03-19 14:38:41 +0000
committerJohn Emmas <johne53@tiscali.co.uk>2014-03-19 14:38:41 +0000
commit97a537cd2138dea1c64d01c5a0fa0f9335893c19 (patch)
tree0c8715707f5211d74799a9fc8832d6e7f9f9556c /libs/ardour/filesystem_paths.cc
parent6b92b1787e12f42e7eeee118aa48216841c5a614 (diff)
Use glibmm to simplify my earlier efforts with 'user_config_directory()' and 'user_cache_directory()'
(improves my previous commit from 10th Mar 2014)
Diffstat (limited to 'libs/ardour/filesystem_paths.cc')
-rw-r--r--libs/ardour/filesystem_paths.cc26
1 files changed, 8 insertions, 18 deletions
diff --git a/libs/ardour/filesystem_paths.cc b/libs/ardour/filesystem_paths.cc
index 78232b16cd..1b4bd0476d 100644
--- a/libs/ardour/filesystem_paths.cc
+++ b/libs/ardour/filesystem_paths.cc
@@ -60,13 +60,8 @@ user_config_directory ()
p = c;
} else {
#ifdef PLATFORM_WINDOWS
- std::string home_dir;
-
- if (0 != PBD::get_win_special_folder(CSIDL_LOCAL_APPDATA)) {
- home_dir = PBD::get_win_special_folder(CSIDL_LOCAL_APPDATA);
- home_dir += "\\";
- home_dir += PROGRAM_NAME;
- }
+ // Not technically the home dir (since it needs to be a writable folder)
+ const string home_dir = Glib::build_filename (Glib::get_user_config_dir(), user_config_dir_name);
#else
const string home_dir = Glib::get_home_dir();
#endif
@@ -80,7 +75,9 @@ user_config_directory ()
}
#endif
+#ifndef PLATFORM_WINDOWS
p = Glib::build_filename (p, user_config_dir_name);
+#endif
if (!Glib::file_test (p, Glib::FILE_TEST_EXISTS)) {
if (g_mkdir_with_parents (p.c_str(), 0755)) {
@@ -111,25 +108,16 @@ user_cache_directory ()
/* adopt freedesktop standards, and put .ardour3 into $XDG_CACHE_HOME
* defaulting to or ~/.config
- *
- * NB this should work on windows, too, but we may want to prefer
- * PBD::get_platform_fallback_folder (PBD::FOLDER_VST) or someplace
*/
if ((c = getenv ("XDG_CACHE_HOME")) != 0) {
p = c;
} else {
#ifdef PLATFORM_WINDOWS
- std::string home_dir;
-
- if (0 != PBD::get_win_special_folder(CSIDL_LOCAL_APPDATA)) {
- home_dir = PBD::get_win_special_folder(CSIDL_LOCAL_APPDATA);
- home_dir += "\\";
- home_dir += PROGRAM_NAME;
- }
+ // Not technically the home dir (since it needs to be a writable folder)
+ const string home_dir = Glib::build_filename (Glib::get_user_data_dir(), user_config_dir_name);
#else
const string home_dir = Glib::get_home_dir();
#endif
-
if (home_dir.empty ()) {
error << "Unable to determine home directory" << endmsg;
exit (1);
@@ -140,7 +128,9 @@ user_cache_directory ()
}
#endif
+#ifndef PLATFORM_WINDOWS
p = Glib::build_filename (p, user_config_dir_name);
+#endif
if (!Glib::file_test (p, Glib::FILE_TEST_EXISTS)) {
if (g_mkdir_with_parents (p.c_str(), 0755)) {