From 668812ca3e4e4dcd200cb46650f93153b6ee3a87 Mon Sep 17 00:00:00 2001 From: BtbN Date: Sat, 25 Jan 2014 22:11:57 +0100 Subject: [PATCH] Adjust file finding functions to also search the install root dir on Windows This is because the installed versions of OBS is allways executed in the install root instead of inside the bin dir. --- libobs/obs-nix.c | 5 +++ libobs/obs-windows.c | 71 ++++++++++++++++++++++++++++++++++------ obs/platform-windows.cpp | 20 ++++++++--- 3 files changed, 82 insertions(+), 14 deletions(-) diff --git a/libobs/obs-nix.c b/libobs/obs-nix.c index c5b69ae5b..1e105c20e 100644 --- a/libobs/obs-nix.c +++ b/libobs/obs-nix.c @@ -63,6 +63,11 @@ char *find_plugin(const char *plugin) if (check_lib_path(plugin, "../../obs-plugins/32bit/", &output)) return output.array; } + else + { + if (check_lib_path(plugin, "../../obs-plugins/64bit/", &output)) + return output.array; + } if (OBS_INSTALL_PREFIX [0] != 0) { diff --git a/libobs/obs-windows.c b/libobs/obs-windows.c index a428752cc..9b0b92dbd 100644 --- a/libobs/obs-windows.c +++ b/libobs/obs-windows.c @@ -20,33 +20,84 @@ #include "obs.h" #include "obs-data.h" +static inline bool check_path(const char* data, const char *path, + struct dstr * output) +{ + dstr_copy(output, path); + dstr_cat(output, data); + + blog(LOG_INFO, "Attempting path: %s\n", output->array); + + return os_file_exists(output->array); +} + +static inline bool check_lib_path(const char* data, const char *path, + struct dstr *output) +{ + bool result = false; + struct dstr tmp; + + dstr_init_copy(&tmp, data); + dstr_cat(&tmp, ".dll"); + result = check_path(tmp.array, path, output); + + dstr_free(&tmp); + + return result; +} + /* on windows, plugin files are located in [base directory]/plugins/[bit] */ char *find_plugin(const char *plugin) { struct dstr path; + dstr_init(&path); + #ifdef _WIN64 - dstr_init_copy(&path, "../../obs-plugins/64bit/"); + if (check_lib_path(plugin, "obs-plugins/64bit/", &path)) #else - dstr_init_copy(&path, "../../obs-plugins/32bit/"); + if (check_lib_path(plugin, "obs-plugins/32bit/", &path)) #endif - dstr_cat(&path, plugin); - return path.array; + return path.array; + +#ifdef _WIN64 + if (check_lib_path(plugin, "../../obs-plugins/64bit/", &path)) +#else + if (check_lib_path(plugin, "../../obs-plugins/32bit/", &path)) +#endif + return path.array; + + dstr_free(&path); + return NULL; } /* on windows, points to [base directory]/libobs */ char *find_libobs_data_file(const char *file) { struct dstr path; - dstr_init_copy(&path, "../../data/libobs/"); - dstr_cat(&path, file); - return path.array; + dstr_init(&path); + + if (check_path(file, "data/libobs/", &path)) + return path.array; + + if (check_path(file, "../../data/libobs/", &path)) + return path.array; + + dstr_free(&path); + return NULL; } /* on windows, data files should always be in [base directory]/data */ char *obs_find_plugin_file(const char *file) { struct dstr path; - dstr_init_copy(&path, "../../data/obs-plugins/"); - dstr_cat(&path, file); - return path.array; + dstr_init(&path); + + if (check_path(file, "data/obs-plugins/", &path)) + return path.array; + + if (check_path(file, "../../data/obs-plugins/", &path)) + return path.array; + + dstr_free(&path); + return NULL; } diff --git a/obs/platform-windows.cpp b/obs/platform-windows.cpp index 0ce0238d1..00a103675 100644 --- a/obs/platform-windows.cpp +++ b/obs/platform-windows.cpp @@ -24,12 +24,24 @@ using namespace std; #define WIN32_LEAN_AND_MEAN #include +static inline bool check_path(const char* data, const char *path, + string &output) +{ + ostringstream str; + str << path << data; + output = str.str(); + + printf("Attempted path: %s\n", output.c_str()); + + return os_file_exists(output.c_str()); +} + bool GetDataFilePath(const char *data, string &output) { - stringstream str; - str << OBS_DATA_PATH "/obs-studio/" << data; - output = str.str(); - return os_file_exists(output.c_str()); + if (check_path(data, "data/obs-studio/", output)) + return true; + + return check_path(data, OBS_DATA_PATH "/obs-studio/", output); } static BOOL CALLBACK OBSMonitorEnumProc(HMONITOR hMonitor, HDC hdcMonitor,