Browse Source

Merge pull request #15475 from sambler/freebsd_execvp

Fix use of execvp for freebsd
Rémi Verschelde 7 years ago
parent
commit
86ef33108e
1 changed files with 13 additions and 11 deletions
  1. 13 11
      drivers/unix/os_unix.cpp

+ 13 - 11
drivers/unix/os_unix.cpp

@@ -53,6 +53,7 @@
 
 
 #if defined(__FreeBSD__) || defined(__OpenBSD__)
 #if defined(__FreeBSD__) || defined(__OpenBSD__)
 #include <sys/param.h>
 #include <sys/param.h>
+#include <sys/sysctl.h>
 #endif
 #endif
 #include "project_settings.h"
 #include "project_settings.h"
 #include <assert.h>
 #include <assert.h>
@@ -298,17 +299,7 @@ Error OS_Unix::execute(const String &p_path, const List<String> &p_arguments, bo
 			args.push_back((char *)cs[i].get_data()); // shitty C cast
 			args.push_back((char *)cs[i].get_data()); // shitty C cast
 		args.push_back(0);
 		args.push_back(0);
 
 
-#ifdef __FreeBSD__
-		if (p_path.find("/") != -1) {
-			// exec name contains path so use it
-			execv(p_path.utf8().get_data(), &args[0]);
-		} else {
-			// use program name and search through PATH to find it
-			execvp(getprogname(), &args[0]);
-		}
-#else
 		execvp(p_path.utf8().get_data(), &args[0]);
 		execvp(p_path.utf8().get_data(), &args[0]);
-#endif
 		// still alive? something failed..
 		// still alive? something failed..
 		fprintf(stderr, "**ERROR** OS_Unix::execute - Could not create child process while executing: %s\n", p_path.utf8().get_data());
 		fprintf(stderr, "**ERROR** OS_Unix::execute - Could not create child process while executing: %s\n", p_path.utf8().get_data());
 		abort();
 		abort();
@@ -462,12 +453,23 @@ String OS_Unix::get_executable_path() const {
 		return OS::get_executable_path();
 		return OS::get_executable_path();
 	}
 	}
 	return b;
 	return b;
-#elif defined(__FreeBSD__) || defined(__OpenBSD__)
+#elif defined(__OpenBSD__)
 	char resolved_path[MAXPATHLEN];
 	char resolved_path[MAXPATHLEN];
 
 
 	realpath(OS::get_executable_path().utf8().get_data(), resolved_path);
 	realpath(OS::get_executable_path().utf8().get_data(), resolved_path);
 
 
 	return String(resolved_path);
 	return String(resolved_path);
+#elif defined(__FreeBSD__)
+	int mib[4] = { CTL_KERN, KERN_PROC, KERN_PROC_PATHNAME, -1 };
+	char buf[MAXPATHLEN];
+	size_t len = sizeof(buf);
+	if (sysctl(mib, 4, buf, &len, NULL, 0) != 0) {
+		WARN_PRINT("Couldn't get executable path from sysctl");
+		return OS::get_executable_path();
+	}
+	String b;
+	b.parse_utf8(buf);
+	return b;
 #elif defined(__APPLE__)
 #elif defined(__APPLE__)
 	char temp_path[1];
 	char temp_path[1];
 	uint32_t buff_size = 1;
 	uint32_t buff_size = 1;