summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorjoerg <joerg@pkgsrc.org>2006-10-08 16:24:26 +0000
committerjoerg <joerg@pkgsrc.org>2006-10-08 16:24:26 +0000
commit32884b213a12d865f2604f543fa6a6e05d4deae7 (patch)
tree2a49ecb4bae9ed93d5684a5bfb349a4851dd6eb0
parente3fe75f49042056462f73350d032fbf4d655793b (diff)
downloadpkgsrc-32884b213a12d865f2604f543fa6a6e05d4deae7.tar.gz
Newer versions of NetBSD have the plague-spot called strndup.
While here, also use errx from the system on BSDs and don't segfault in strndup if malloc failed. From Don Woodstock in #netbsd-code.
-rw-r--r--graphics/gimp1-base/files/pdb_self_doc.c16
1 files changed, 11 insertions, 5 deletions
diff --git a/graphics/gimp1-base/files/pdb_self_doc.c b/graphics/gimp1-base/files/pdb_self_doc.c
index d7f6e408517..bdabaa8d386 100644
--- a/graphics/gimp1-base/files/pdb_self_doc.c
+++ b/graphics/gimp1-base/files/pdb_self_doc.c
@@ -1,4 +1,4 @@
-/* $NetBSD: pdb_self_doc.c,v 1.1.1.1 2004/03/29 22:06:49 xtraeme Exp $ */
+/* $NetBSD: pdb_self_doc.c,v 1.2 2006/10/08 16:24:26 joerg Exp $ */
/*
* C version of pdb_self_doc.el, makes some assumptions about the structure
@@ -11,13 +11,15 @@
#include <ctype.h>
#ifdef __NetBSD__
-#include <err.h>
+#include <sys/param.h>
#endif
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
-#ifndef __NetBSD__
+#if defined(__NetBSD__) || defined(__DragonFly__) || defined(__FreeBSD__) || defined(__OpenBSD__)
+#include <err.h>
+#else
#include <stdarg.h>
void errx (int rc, char *fmt,...)
{
@@ -50,12 +52,16 @@ int nprocs;
#define wsspan(p) strspn(p, " \t\r\n")
+#if !(defined(__NetBSD__) && __NetBSD_Version__ >= 400000000)
static char *strndup(const char *x, int len) {
char *p = malloc(len + 1);
- strncpy(p, x, len);
- p[len] = 0;
+ if(p != NULL) {
+ strncpy(p, x, len);
+ p[len] = 0;
+ }
return p;
}
+#endif
static int proccompar(const void *a, const void *b) {
return strcmp(((struct procedure *)a)->hlist[0],