X-Git-Url: http://pileus.org/git/?a=blobdiff_plain;f=xmalloc.c;h=c2ca4a66e932a32d99716d851914b13ca05da6f0;hb=49268a95ee78bc179fd3439b3f06e9a06c993c92;hp=ed0b88e73fc68464c51ea17e6a46eab3f22cedcf;hpb=acb741c73356b37fbc9dac0ffb7739cc63170433;p=~andy%2Ffetchmail diff --git a/xmalloc.c b/xmalloc.c index ed0b88e7..c2ca4a66 100644 --- a/xmalloc.c +++ b/xmalloc.c @@ -6,6 +6,7 @@ */ #include "config.h" +#include #include #include #include @@ -22,24 +23,30 @@ #endif XMALLOCTYPE * -xmalloc (int n) +xmalloc (size_t n) { XMALLOCTYPE *p; p = (XMALLOCTYPE *) malloc(n); if (p == (XMALLOCTYPE *) 0) - error(PS_UNDEFINED, errno, _("malloc failed")); + { + 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) - error(PS_UNDEFINED, errno, _("realloc failed")); + { + report(stderr, GT_("realloc failed\n")); + abort(); + } return p; } @@ -51,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 */