try get_win_special_folder() for harvid & xjadeo (if registry fails)
authorRobin Gareus <robin@gareus.org>
Thu, 24 Apr 2014 11:22:17 +0000 (13:22 +0200)
committerRobin Gareus <robin@gareus.org>
Thu, 24 Apr 2014 11:22:17 +0000 (13:22 +0200)
gtk2_ardour/video_server_dialog.cc
gtk2_ardour/video_timeline.cc

index f9a50821b54527580c05281ac446788b04b38e1d..e4c9a7f51abf0d5e07a698c5477ce4f9e8fdac26 100644 (file)
 #include "ardour/template_utils.h"
 #include "ardour/session.h"
 
+#ifdef PLATFORM_WINDOWS
+#include <windows.h>
+#include <shlobj.h> // CSIDL_*
+#include "pbd/windows_special_dirs.h"
+#endif
+
 #ifdef interface
 #undef interface
 #endif
@@ -87,6 +93,7 @@ VideoServerDialog::VideoServerDialog (Session* s)
        HKEY key;
        DWORD size = PATH_MAX;
        char tmp[PATH_MAX+1];
+       const char *program_files = PBD::get_win_special_folder (CSIDL_PROGRAM_FILES);
 #endif
 
        std::string icsd_file_path;
@@ -100,7 +107,12 @@ VideoServerDialog::VideoServerDialog (Session* s)
        {
                path_entry.set_text(g_build_filename(Glib::locale_to_utf8(tmp).c_str(), "harvid.exe", 0));
        }
+       else if (program_files && Glib::file_test(g_build_filename(program_files, "harvid", "harvid.exe", 0), Glib::FILE_TEST_EXISTS))
+       {
+               path_entry.set_text(g_build_filename(program_files, "harvid", "harvid.exe", 0));
+       }
 #endif
+       /* generic fallbacks to try */
        else if (Glib::file_test(X_("C:\\Program Files\\harvid\\harvid.exe"), Glib::FILE_TEST_EXISTS)) {
                path_entry.set_text(X_("C:\\Program Files\\harvid\\harvid.exe"));
        }
index 0ef0f4c5d853cc0c590b38477d79800f0a0131b2..0defa56be7a3448ec215de34af7c126cab81d3a5 100644 (file)
 #include "pbd/convert.h"
 #include "ardour/session_directory.h"
 
+#ifdef PLATFORM_WINDOWS
+#include <windows.h>
+#include <shlobj.h> // CSIDL_*
+#include "pbd/windows_special_dirs.h"
+#endif
+
 #include "ardour_ui.h"
 #include "public_editor.h"
 #include "gui_thread.h"
@@ -720,6 +726,7 @@ VideoTimeLine::find_xjadeo () {
        HKEY key;
        DWORD size = PATH_MAX;
        char tmp[PATH_MAX+1];
+       const char *program_files = PBD::get_win_special_folder (CSIDL_PROGRAM_FILES);
 #endif
        if (getenv("XJREMOTE")) {
                _xjadeo_bin = getenv("XJREMOTE");
@@ -740,7 +747,12 @@ VideoTimeLine::find_xjadeo () {
        {
                _xjadeo_bin = std::string(g_build_filename(Glib::locale_to_utf8(tmp).c_str(), "xjadeo.exe", 0));
        }
+       else if (program_files && Glib::file_test(g_build_filename(program_files, "xjadeo", "xjadeo.exe", 0), Glib::FILE_TEST_EXISTS))
+       {
+               _xjadeo_bin = std::string(g_build_filename(program_files, "harvid", "xjadeo.exe", 0));
+       }
 #endif
+       /* generic fallbacks to try */
 #ifdef __APPLE__
        else if (Glib::file_test(X_("/Applications/Jadeo.app/Contents/MacOS/xjremote"), Glib::FILE_TEST_EXISTS|Glib::FILE_TEST_IS_EXECUTABLE)) {
                _xjadeo_bin = X_("/Applications/Jadeo.app/Contents/MacOS/xjremote");