Remove frame conversion for MidiRegionView::note_in_region_range(), speed up tempo...
[ardour.git] / libs / ardour / ardour / filesystem_paths.h
index b96cd051377a0f27c16c95d075e4ae82fe373f58..83f50fd1691609d719221dc15d8fa80e39ff8017 100644 (file)
 namespace ARDOUR {
 
        /**
-        * @return the path to the directory used to store user specific ardour
-        * configuration files.
-        * @post user_config_directory() exists
+        * @return the path to the directory used to store user specific
+        * configuration files for the given @param version of the program.
+        * If @param version is negative, the build-time string PROGRAM_VERSION
+        * will be used to determine the version number.
+        *
+        * @post user_config_directory() exists IF version was negative.
+        *
+        *
         */
-       LIBARDOUR_API std::string user_config_directory ();
+        LIBARDOUR_API std::string user_config_directory (int version = -1);
+
+       /**
+        * @return the path to the directory used to store user specific
+        * caches (e.g. plugin indices, blacklist/whitelist)
+        * it defaults to XDG_CACHE_HOME
+        */
+       LIBARDOUR_API std::string user_cache_directory ();
+
+       /**
+        * @return the path used to store a persistent indication
+        * that the given version of the program has been used before.
+        *
+        * @param version is the version to check for. If unspecified,
+        * it defaults to the current (build-time) version of the program.
+        */
+       LIBARDOUR_API std::string been_here_before_path (int version = -1);
 
        /**
         * @return the path to the directory that contains the system wide ardour
@@ -43,15 +64,28 @@ namespace ARDOUR {
         * @return the search path to be used when looking for per-system
         * configuration files. This may include user configuration files.
         */
-       LIBARDOUR_API PBD::SearchPath ardour_config_search_path ();
+       LIBARDOUR_API PBD::Searchpath ardour_config_search_path ();
 
        /**
         * @return the search path to be used when looking for data files
         * that could be shared by systems (h/w and configuration independent
         * files, such as icons, XML files, etc)
         */
-       LIBARDOUR_API PBD::SearchPath ardour_data_search_path ();
+       LIBARDOUR_API PBD::Searchpath ardour_data_search_path ();
 
+#ifdef PLATFORM_WINDOWS
+       /**
+        * @return our 'Windows' search path ( corresponds to <install_dir>/share/ardour3 )
+        */
+       LIBARDOUR_API PBD::Searchpath windows_search_path ();
+
+       /**
+        * @return Convenience function that calls
+        * g_win32_get_package_installation_directory_of_module but returns a
+        * std::string
+        */
+       LIBARDOUR_API std::string windows_package_directory_path ();
+#endif
 } // namespace ARDOUR
 
 #endif