X-Git-Url: http://pileus.org/git/?a=blobdiff_plain;f=xmalloc.c;h=c2ca4a66e932a32d99716d851914b13ca05da6f0;hb=f6c7034fdbeb25d7d8eb0e62c0fe5de563eb7b55;hp=6d63cde846fe4608ad95c04512916f69c3e7a343;hpb=b476ac337200fe5ed62494feb1280652eae57025;p=~andy%2Ffetchmail diff --git a/xmalloc.c b/xmalloc.c index 6d63cde8..c2ca4a66 100644 --- a/xmalloc.c +++ b/xmalloc.c @@ -6,6 +6,7 @@ */ #include "config.h" +#include #include #include #include @@ -22,29 +23,29 @@ #endif XMALLOCTYPE * -xmalloc (int n) +xmalloc (size_t n) { XMALLOCTYPE *p; p = (XMALLOCTYPE *) malloc(n); if (p == (XMALLOCTYPE *) 0) { - report(stderr, errno, _("malloc failed")); - exit(PS_UNDEFINED); + report(stderr, GT_("malloc failed\n")); + abort(); } return(p); } XMALLOCTYPE * -xrealloc (XMALLOCTYPE *p, int n) +xrealloc (XMALLOCTYPE *p, size_t n) { if (p == 0) return xmalloc (n); p = (XMALLOCTYPE *) realloc(p, n); if (p == (XMALLOCTYPE *) 0) { - report(stderr, errno, _("realloc failed")); - exit(PS_UNDEFINED); + report(stderr, GT_("realloc failed\n")); + abort(); } return p; } @@ -57,4 +58,27 @@ char *xstrdup(const char *s) return p; } +#if !defined(HAVE_STRDUP) +char *strdup(const char *s) +{ + char *p; + p = (char *) malloc(strlen(s)+1); + if (p) + strcpy(p,s); + return p; +} +#endif /* !HAVE_STRDUP */ + +char *xstrndup(const char *s, size_t len) +{ + char *p; + size_t l = strlen(s); + + if (len < l) l = len; + p = (char *)xmalloc(l + 1); + memcpy(p, s, l); + p[l] = '\0'; + return p; +} + /* xmalloc.c ends here */