Loading...
gen/FreeBSD/setprogname.c.patch Libc-594.9.5 /dev/null
--- Libc/Libc-594.9.5/gen/FreeBSD/setprogname.c.patch
+++ /dev/null
@@ -1,37 +0,0 @@
---- setprogname.c.orig	2008-01-31 02:47:06.000000000 -0800
-+++ setprogname.c	2008-01-31 03:07:50.000000000 -0800
-@@ -3,6 +3,10 @@
- 
- #include <stdlib.h>
- #include <string.h>
-+#include <sys/param.h>
-+#include <sys/sysctl.h>
-+#include <crt_externs.h>
-+#define	__progname	(*_NSGetProgname())
- 
- #include "libc_private.h"
- 
-@@ -10,10 +14,20 @@
- setprogname(const char *progname)
- {
- 	const char *p;
--
-+	char buf[2*MAXCOMLEN+1];
-+	int mib[2];
-+	
- 	p = strrchr(progname, '/');
- 	if (p != NULL)
--		__progname = p + 1;
-+		__progname = (char *)(p + 1);
- 	else
--		__progname = progname;
-+		__progname = (char *)(p = progname);
-+
-+	strlcpy(&buf[0], (char *)(p), sizeof(buf));
-+
-+	mib[0] = CTL_KERN;
-+	mib[1] = KERN_PROCNAME;
-+
-+	/* ignore errors as this is not a hard error */
-+	sysctl(mib, 2, NULL, NULL, &buf[0], strlen(buf));
- }