فهرست منبع

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.
BtbN 12 سال پیش
والد
کامیت
668812ca3e
3فایلهای تغییر یافته به همراه81 افزوده شده و 13 حذف شده
  1. 5 0
      libobs/obs-nix.c
  2. 61 10
      libobs/obs-windows.c
  3. 15 3
      obs/platform-windows.cpp

+ 5 - 0
libobs/obs-nix.c

@@ -63,6 +63,11 @@ char *find_plugin(const char *plugin)
 		if (check_lib_path(plugin, "../../obs-plugins/32bit/", &output))
 		if (check_lib_path(plugin, "../../obs-plugins/32bit/", &output))
 			return output.array;
 			return output.array;
 	}
 	}
+	else
+	{
+		if (check_lib_path(plugin, "../../obs-plugins/64bit/", &output))
+			return output.array;
+	}
 
 
 	if (OBS_INSTALL_PREFIX [0] != 0)
 	if (OBS_INSTALL_PREFIX [0] != 0)
 	{
 	{

+ 61 - 10
libobs/obs-windows.c

@@ -20,33 +20,84 @@
 #include "obs.h"
 #include "obs.h"
 #include "obs-data.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] */
 /* on windows, plugin files are located in [base directory]/plugins/[bit] */
 char *find_plugin(const char *plugin)
 char *find_plugin(const char *plugin)
 {
 {
 	struct dstr path;
 	struct dstr path;
+	dstr_init(&path);
+
 #ifdef _WIN64
 #ifdef _WIN64
-	dstr_init_copy(&path, "../../obs-plugins/64bit/");
+	if (check_lib_path(plugin, "obs-plugins/64bit/", &path))
 #else
 #else
-	dstr_init_copy(&path, "../../obs-plugins/32bit/");
+	if (check_lib_path(plugin, "obs-plugins/32bit/", &path))
 #endif
 #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 */
 /* on windows, points to [base directory]/libobs */
 char *find_libobs_data_file(const char *file)
 char *find_libobs_data_file(const char *file)
 {
 {
 	struct dstr path;
 	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 */
 /* on windows, data files should always be in [base directory]/data */
 char *obs_find_plugin_file(const char *file)
 char *obs_find_plugin_file(const char *file)
 {
 {
 	struct dstr path;
 	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;
 }
 }

+ 15 - 3
obs/platform-windows.cpp

@@ -24,14 +24,26 @@ using namespace std;
 #define WIN32_LEAN_AND_MEAN
 #define WIN32_LEAN_AND_MEAN
 #include <windows.h>
 #include <windows.h>
 
 
-bool GetDataFilePath(const char *data, string &output)
+static inline bool check_path(const char* data, const char *path,
+		string &output)
 {
 {
-	stringstream str;
-	str << OBS_DATA_PATH "/obs-studio/" << data;
+	ostringstream str;
+	str << path << data;
 	output = str.str();
 	output = str.str();
+
+	printf("Attempted path: %s\n", output.c_str());
+
 	return os_file_exists(output.c_str());
 	return os_file_exists(output.c_str());
 }
 }
 
 
+bool GetDataFilePath(const char *data, string &output)
+{
+	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,
 static BOOL CALLBACK OBSMonitorEnumProc(HMONITOR hMonitor, HDC hdcMonitor,
 		LPRECT rect, LPARAM param)
 		LPRECT rect, LPARAM param)
 {
 {