summaryrefslogtreecommitdiffstats
path: root/drivers/unix
diff options
context:
space:
mode:
authorRémi Verschelde <rverschelde@gmail.com>2024-01-04 14:25:46 +0100
committerRémi Verschelde <rverschelde@gmail.com>2024-01-04 14:25:46 +0100
commitc921b6587c1efb1d0583187c89aa868ee780ba21 (patch)
tree9d511b1623dc58996605d57f8d10dfda39cd2055 /drivers/unix
parent5fd5176a790b6ec99dac64b9f6a41e4c84967d6b (diff)
parent52da1e9b6b96057efd8ab8039978828114d92564 (diff)
downloadredot-engine-c921b6587c1efb1d0583187c89aa868ee780ba21.tar.gz
Merge pull request #84469 from time-killer-games/patch-1
Fix NetBSD executable path
Diffstat (limited to 'drivers/unix')
-rw-r--r--drivers/unix/os_unix.cpp17
1 files changed, 16 insertions, 1 deletions
diff --git a/drivers/unix/os_unix.cpp b/drivers/unix/os_unix.cpp
index 50abd5af42..51ea9234d4 100644
--- a/drivers/unix/os_unix.cpp
+++ b/drivers/unix/os_unix.cpp
@@ -753,12 +753,27 @@ String OS_Unix::get_executable_path() const {
return OS::get_executable_path();
}
return b;
-#elif defined(__OpenBSD__) || defined(__NetBSD__)
+#elif defined(__OpenBSD__)
char resolved_path[MAXPATHLEN];
realpath(OS::get_executable_path().utf8().get_data(), resolved_path);
return String(resolved_path);
+#elif defined(__NetBSD__)
+ int mib[4] = { CTL_KERN, KERN_PROC_ARGS, -1, KERN_PROC_PATHNAME };
+ char buf[MAXPATHLEN];
+ size_t len = sizeof(buf);
+ if (sysctl(mib, 4, buf, &len, nullptr, 0) != 0) {
+ WARN_PRINT("Couldn't get executable path from sysctl");
+ return OS::get_executable_path();
+ }
+
+ // NetBSD does not always return a normalized path. For example if argv[0] is "./a.out" then executable path is "/home/netbsd/./a.out". Normalize with realpath:
+ char resolved_path[MAXPATHLEN];
+
+ realpath(buf, resolved_path);
+
+ return String(resolved_path);
#elif defined(__FreeBSD__)
int mib[4] = { CTL_KERN, KERN_PROC, KERN_PROC_PATHNAME, -1 };
char buf[MAXPATHLEN];