FreeBSD: fix Get_program_directory() when launched from the path
This commit is contained in:
parent
ea7f66de74
commit
0e538b99f6
12
src/setup.c
12
src/setup.c
@ -43,6 +43,7 @@
|
|||||||
#import <sys/param.h>
|
#import <sys/param.h>
|
||||||
#elif defined(__FreeBSD__)
|
#elif defined(__FreeBSD__)
|
||||||
#include <sys/param.h>
|
#include <sys/param.h>
|
||||||
|
#include <unistd.h>
|
||||||
#elif defined(__MINT__)
|
#elif defined(__MINT__)
|
||||||
#include <mint/osbind.h>
|
#include <mint/osbind.h>
|
||||||
#include <mint/sysbind.h>
|
#include <mint/sysbind.h>
|
||||||
@ -114,12 +115,17 @@ char * Get_program_directory(const char * argv0)
|
|||||||
getcwd(program_dir, MAX_PATH_CHARACTERS);
|
getcwd(program_dir, MAX_PATH_CHARACTERS);
|
||||||
strcat(program_dir, "/");
|
strcat(program_dir, "/");
|
||||||
// Linux: argv[0] unreliable
|
// Linux: argv[0] unreliable
|
||||||
#elif defined(__linux__)
|
#elif defined(__linux__) || defined(__FreeBSD__)
|
||||||
|
#if defined(__linux__)
|
||||||
|
#define SELF_PATH "/proc/self/exe"
|
||||||
|
#elif defined(__FreeBSD__)
|
||||||
|
#define SELF_PATH "/proc/curproc/file"
|
||||||
|
#endif
|
||||||
if (argv0[0]!='/')
|
if (argv0[0]!='/')
|
||||||
{
|
{
|
||||||
ssize_t path_len;
|
ssize_t path_len;
|
||||||
char path[PATH_MAX];
|
char path[PATH_MAX];
|
||||||
path_len = readlink("/proc/self/exe", path, sizeof(path));
|
path_len = readlink(SELF_PATH, path, sizeof(path));
|
||||||
if (path_len >= 0)
|
if (path_len >= 0)
|
||||||
{
|
{
|
||||||
path[path_len] = '\0'; // add null terminating char
|
path[path_len] = '\0'; // add null terminating char
|
||||||
@ -132,7 +138,7 @@ char * Get_program_directory(const char * argv0)
|
|||||||
size_t len;
|
size_t len;
|
||||||
|
|
||||||
program_dir = NULL;
|
program_dir = NULL;
|
||||||
GFX2_Log(GFX2_WARNING, "readlink(%s) failed : %s\n", "/proc/self/exe", strerror(errno));
|
GFX2_Log(GFX2_WARNING, "readlink(%s) failed : %s\n", SELF_PATH, strerror(errno));
|
||||||
current_dir = Get_current_directory(NULL, NULL, 0);
|
current_dir = Get_current_directory(NULL, NULL, 0);
|
||||||
if (current_dir != NULL)
|
if (current_dir != NULL)
|
||||||
{
|
{
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user