Just noticed a small problem with my previous commit. Windows config files should...
[ardour.git] / libs / ardour / filesystem_paths.cc
index 8d48ea3068ec3458528f36bb1cd45002c53b609f..d889076717541d5ee13c37edbce795f587b6bf80 100644 (file)
 
 #include "i18n.h"
 
+#ifdef PLATFORM_WINDOWS
+#include "shlobj.h"
+#include "pbd/windows_special_dirs.h"
+#endif
+
 using namespace PBD;
 
 namespace ARDOUR {
@@ -54,8 +59,17 @@ user_config_directory ()
        if ((c = getenv ("XDG_CONFIG_HOME")) != 0) {
                p = c;
        } else {
-               const string home_dir = Glib::get_home_dir();
+#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;
+               }
+#else
+               const string home_dir = Glib::get_home_dir();
+#endif
                if (home_dir.empty ()) {
                        error << "Unable to determine home directory" << endmsg;
                        exit (1);
@@ -83,6 +97,66 @@ user_config_directory ()
        return p;
 }
 
+std::string
+user_cache_directory ()
+{
+       static std::string p;
+
+       if (!p.empty()) return p;
+
+#ifdef __APPLE__
+       p = Glib::build_filename (Glib::get_home_dir(), "Library/Caches");
+#else
+       const char* c = 0;
+
+       /* 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;
+               }
+#else
+               const string home_dir = Glib::get_home_dir();
+#endif
+
+               if (home_dir.empty ()) {
+                       error << "Unable to determine home directory" << endmsg;
+                       exit (1);
+               }
+
+               p = home_dir;
+               p = Glib::build_filename (p, ".cache");
+       }
+#endif
+
+       p = Glib::build_filename (p, user_config_dir_name);
+
+       if (!Glib::file_test (p, Glib::FILE_TEST_EXISTS)) {
+               if (g_mkdir_with_parents (p.c_str(), 0755)) {
+                       error << string_compose (_("Cannot create cache directory %1 - cannot run"),
+                                                  p) << endmsg;
+                       exit (1);
+               }
+       } else if (!Glib::file_test (p, Glib::FILE_TEST_IS_DIR)) {
+               error << string_compose (_("Cache directory %1 already exists and is not a directory/folder - cannot run"),
+                                          p) << endmsg;
+               exit (1);
+       }
+
+       return p;
+}
+
 std::string
 ardour_dll_directory ()
 {
@@ -101,7 +175,7 @@ ardour_dll_directory ()
 }
 
 #ifdef PLATFORM_WINDOWS
-SearchPath
+Searchpath
 windows_search_path ()
 {
        std::string dll_dir_path(g_win32_get_package_installation_directory_of_module(NULL));
@@ -110,10 +184,10 @@ windows_search_path ()
 }
 #endif
 
-SearchPath
+Searchpath
 ardour_config_search_path ()
 {
-       static SearchPath search_path;
+       static Searchpath search_path;
 
        if (search_path.empty()) {
                search_path += user_config_directory();
@@ -126,17 +200,17 @@ ardour_config_search_path ()
                        ::exit (1);
                }
                
-               search_path += SearchPath (s);
+               search_path += Searchpath (s);
 #endif
        }
 
        return search_path;
 }
 
-SearchPath
+Searchpath
 ardour_data_search_path ()
 {
-       static SearchPath search_path;
+       static Searchpath search_path;
 
        if (search_path.empty()) {
                search_path += user_config_directory();
@@ -149,7 +223,7 @@ ardour_data_search_path ()
                        ::exit (1);
                }
                
-               search_path += SearchPath (s);
+               search_path += Searchpath (s);
 #endif
        }