X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Fxmalloc.c;h=01ac54824815daf95d989a2b0ff3bfed5c6302bf;hb=ac5e11c593de9d8a862193b328a2def30e6d3447;hp=8217c992d7ac7ab6365cd3dff8a1bc66aff38aff;hpb=8bc2863c9a53466fda8f50603df297df9233c285;p=gnulib.git diff --git a/lib/xmalloc.c b/lib/xmalloc.c index 8217c992d..01ac54824 100644 --- a/lib/xmalloc.c +++ b/lib/xmalloc.c @@ -1,5 +1,5 @@ /* xmalloc.c -- malloc with out of memory checking - Copyright (C) 1990, 91, 92, 93, 94, 95, 96 Free Software Foundation, Inc. + Copyright (C) 1990-1997, 98 Free Software Foundation, Inc. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -19,20 +19,14 @@ # include #endif -#if __STDC__ -# define VOID void -#else -# define VOID char -#endif - #include #if STDC_HEADERS # include #else -VOID *calloc (); -VOID *malloc (); -VOID *realloc (); +void *calloc (); +void *malloc (); +void *realloc (); void free (); #endif @@ -43,87 +37,77 @@ void free (); # define textdomain(Domain) # define _(Text) Text #endif +#define N_(Text) Text #include "error.h" +#include "xalloc.h" #ifndef EXIT_FAILURE # define EXIT_FAILURE 1 #endif -/* Prototypes for functions defined here. */ -#if defined (__STDC__) && __STDC__ -static VOID *fixup_null_alloc (size_t n); -VOID *xmalloc (size_t n); -VOID *xcalloc (size_t n, size_t s); -VOID *xrealloc (VOID *p, size_t n); +#ifndef HAVE_DONE_WORKING_MALLOC_CHECK +you must run the autoconf test for a properly working malloc -- see malloc.m4 #endif +#ifndef HAVE_DONE_WORKING_REALLOC_CHECK +you must run the autoconf test for a properly working realloc -- see realloc.m4 +#endif /* Exit value when the requested amount of memory is not available. The caller may set it to some other value. */ -int xmalloc_exit_failure = EXIT_FAILURE; +int xalloc_exit_failure = EXIT_FAILURE; -#if __STDC__ && (HAVE_VPRINTF || HAVE_DOPRNT) -void error (int, int, const char *, ...); -#else -void error (); -#endif +/* If non NULL, call this function when memory is exhausted. */ +void (*xalloc_fail_func) () = 0; -static VOID * -fixup_null_alloc (n) - size_t n; -{ - VOID *p; +/* If XALLOC_FAIL_FUNC is NULL, or does return, display this message + before exiting when memory is exhausted. Goes through gettext. */ +char *const xalloc_msg_memory_exhausted = N_("Memory exhausted"); - p = 0; - if (n == 0) - p = malloc ((size_t) 1); - if (p == 0) - error (xmalloc_exit_failure, 0, _("Memory exhausted")); - return p; +static void +xalloc_fail (void) +{ + if (xalloc_fail_func) + (*xalloc_fail_func) (); + error (xalloc_exit_failure, 0, xalloc_msg_memory_exhausted); } /* Allocate N bytes of memory dynamically, with error checking. */ -VOID * -xmalloc (n) - size_t n; +void * +xmalloc (size_t n) { - VOID *p; + void *p; p = malloc (n); if (p == 0) - p = fixup_null_alloc (n); + xalloc_fail (); return p; } -/* Allocate memory for N elements of S bytes, with error checking. */ +/* Change the size of an allocated block of memory P to N bytes, + with error checking. + If P is NULL, run xmalloc. */ -VOID * -xcalloc (n, s) - size_t n, s; +void * +xrealloc (void *p, size_t n) { - VOID *p; - - p = calloc (n, s); + p = realloc (p, n); if (p == 0) - p = fixup_null_alloc (n); + xalloc_fail (); return p; } -/* Change the size of an allocated block of memory P to N bytes, - with error checking. - If P is NULL, run xmalloc. */ +/* Allocate memory for N elements of S bytes, with error checking. */ -VOID * -xrealloc (p, n) - VOID *p; - size_t n; +void * +xcalloc (size_t n, size_t s) { + void *p; + + p = calloc (n, s); if (p == 0) - return xmalloc (n); - p = realloc (p, n); - if (p == 0) - p = fixup_null_alloc (n); + xalloc_fail (); return p; }