diff options
-rw-r--r-- | libexec/ld.so/ldconfig/etc.c | 86 | ||||
-rw-r--r-- | libexec/ld.so/ldconfig/ld.h | 4 |
2 files changed, 33 insertions, 57 deletions
diff --git a/libexec/ld.so/ldconfig/etc.c b/libexec/ld.so/ldconfig/etc.c index 5177fa18c55..caa0710d5e1 100644 --- a/libexec/ld.so/ldconfig/etc.c +++ b/libexec/ld.so/ldconfig/etc.c @@ -1,81 +1,57 @@ -/* * $OpenBSD: etc.c,v 1.3 2001/12/07 18:45:32 mpech Exp $*/ -/* - */ +/* $OpenBSD: etc.c,v 1.4 2002/05/24 00:25:42 ericj Exp $ */ + +/* Public Domain */ + +#include <sys/types.h> #include <err.h> #include <stdlib.h> #include <string.h> -/* - * Like strdup but get fatal error if memory is exhausted. - */ +#define OOM_MSG "Out of memory" + char * -xstrdup(s) - char*s; +xstrdup(const char *s) { - char *result = strdup(s); + char *ptr; - if (!result) - errx(1, "virtual memory exhausted"); - - return result; + if ((ptr = strdup(s)) == NULL) + err(1, OOM_MSG); + return (ptr); } -/* - * Like malloc but get fatal error if memory is exhausted. - */ void * -xmalloc(size) - size_t size; +xmalloc(size_t size) { - void *result = (void *)malloc(size); - - if (!result) - errx(1, "virtual memory exhausted"); + void *ptr; - return result; + if ((ptr = malloc(size)) == NULL) + err(1, OOM_MSG); + return (ptr); } -/* - * Like realloc but get fatal error if memory is exhausted. - */ void * -xrealloc(ptr, size) - void *ptr; - size_t size; +xrealloc(void *ptr, size_t size) { - void *result; - - if (ptr == NULL) - result = (void *)malloc(size); - else - result = (void *)realloc(ptr, size); + void *nptr; - if (!result) - errx(1, "virtual memory exhausted"); - - return result; + if ((nptr = realloc(ptr, size)) == NULL) + err(1, OOM_MSG); + return (nptr); } -/* - * Return a newly-allocated string whose contents concatenate - * the strings S1, S2, S3. - */ char * -concat(s1, s2, s3) - const char *s1, *s2, *s3; +concat(const char *s1, const char *s2, const char *s3) { - int len1 = strlen(s1), - len2 = strlen(s2), - len3 = strlen(s3); + char *str; + size_t len; - char *result = (char *)xmalloc(len1 + len2 + len3 + 1); + len = strlen(s1) + strlen(s2) + strlen(s3) + 1; + str = xmalloc(len); - strcpy(result, s1); - strcpy(result + len1, s2); - strcpy(result + len1 + len2, s3); - result[len1 + len2 + len3] = 0; + strlcpy(str, s1, len); + strlcat(str, s2, len); + strlcat(str, s3, len); - return result; + return (str); } - diff --git a/libexec/ld.so/ldconfig/ld.h b/libexec/ld.so/ldconfig/ld.h index d9b9be014d8..30abc5c7bba 100644 --- a/libexec/ld.so/ldconfig/ld.h +++ b/libexec/ld.so/ldconfig/ld.h @@ -1,4 +1,4 @@ -/* $OpenBSD: ld.h,v 1.4 2002/02/16 21:27:30 millert Exp $ */ +/* $OpenBSD: ld.h,v 1.5 2002/05/24 00:25:42 ericj Exp $ */ /* * Header file to make code compatible with ELF version * ldconfig was taken from the a.out ld. @@ -7,7 +7,7 @@ extern int n_search_dirs; extern char **search_dirs; -char *xstrdup(char *); +char *xstrdup(const char *); void *xmalloc(size_t); void *xrealloc(void *, size_t); char *concat(const char *, const char *, const char *); |