mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-14 16:26:17 +01:00
goption: implement platform_get_argv0() for OpenBSD
https://bugzilla.gnome.org/show_bug.cgi?id=669024
This commit is contained in:
parent
18cb864d12
commit
e43a98c000
@ -139,6 +139,13 @@
|
||||
#include <stdio.h>
|
||||
#include <errno.h>
|
||||
|
||||
#if defined __OpenBSD__
|
||||
#include <sys/types.h>
|
||||
#include <unistd.h>
|
||||
#include <sys/param.h>
|
||||
#include <sys/sysctl.h>
|
||||
#endif
|
||||
|
||||
#include "goption.h"
|
||||
|
||||
#include "gprintf.h"
|
||||
@ -1664,7 +1671,7 @@ free_pending_nulls (GOptionContext *context,
|
||||
static char *
|
||||
platform_get_argv0 (void)
|
||||
{
|
||||
#ifdef __linux
|
||||
#if defined __linux
|
||||
char *cmdline;
|
||||
char *base_arg0;
|
||||
gsize len;
|
||||
@ -1684,6 +1691,28 @@ platform_get_argv0 (void)
|
||||
base_arg0 = g_path_get_basename (cmdline);
|
||||
g_free (cmdline);
|
||||
return base_arg0;
|
||||
#elif defined __OpenBSD__
|
||||
char **cmdline = NULL;
|
||||
char *base_arg0;
|
||||
gsize len = PATH_MAX;
|
||||
|
||||
int mib[] = { CTL_KERN, KERN_PROC_ARGS, getpid(), KERN_PROC_ARGV };
|
||||
|
||||
cmdline = (char **) realloc (cmdline, len);
|
||||
|
||||
if (sysctl (mib, nitems (mib), cmdline, &len, NULL, 0) == -1)
|
||||
{
|
||||
g_free (cmdline);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* We could just return cmdline, but I think it's better
|
||||
* to hold on to a smaller malloc block; the arguments
|
||||
* could be large.
|
||||
*/
|
||||
base_arg0 = g_path_get_basename (*cmdline);
|
||||
g_free (cmdline);
|
||||
return base_arg0;
|
||||
#endif
|
||||
|
||||
return NULL;
|
||||
|
@ -27,7 +27,7 @@
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
|
||||
#ifdef __linux
|
||||
#if defined __linux || defined __OpenBSD__
|
||||
static void
|
||||
test_platform_argv0 (void)
|
||||
{
|
||||
@ -57,7 +57,7 @@ main (int argc,
|
||||
/* Note - we can't actually use g_test_* because g_test_init mutates
|
||||
* g_get_prgname() which is exactly what we wanted to test =/
|
||||
*/
|
||||
#ifdef __linux
|
||||
#if defined __linux || defined __OpenBSD__
|
||||
g_print ("/option/argv0: ");
|
||||
test_platform_argv0 ();
|
||||
g_print ("OK\n");
|
||||
|
Loading…
Reference in New Issue
Block a user