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.
This commit is contained in:
BtbN 2014-01-25 22:11:57 +01:00
parent cfc3609a4e
commit 668812ca3e
3 changed files with 82 additions and 14 deletions

View file

@ -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)
{

View file

@ -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;
}

View file

@ -24,12 +24,24 @@ using namespace std;
#define WIN32_LEAN_AND_MEAN
#include <windows.h>
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,