diff options
author | Jim Meyering <jim@meyering.net> | 1997-10-25 21:51:21 +0000 |
---|---|---|
committer | Jim Meyering <jim@meyering.net> | 1997-10-25 21:51:21 +0000 |
commit | e6503ed629715c968247d8a2c6f1654eb1fc7f6d (patch) | |
tree | bf8d7ed78b8999562d8e728079e73590a774f132 /lib | |
parent | 01b84d9480ef51a21a143bdc647f31331a05c639 (diff) | |
download | coreutils-e6503ed629715c968247d8a2c6f1654eb1fc7f6d.tar.xz |
Include xalloc.h.
Change VOID to void.
(xalloc_exit_failure): Renamed extern.
(xalloc_msg_memory_exhausted): New extern.
(xalloc_fail_func): New extern.
(fixup_null_alloc): Use new variables.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/xmalloc.c | 54 |
1 files changed, 30 insertions, 24 deletions
diff --git a/lib/xmalloc.c b/lib/xmalloc.c index 8217c992d..22b091021 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, 91, 92, 93, 94, 95, 96, 97 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 <config.h> #endif -#if __STDC__ -# define VOID void -#else -# define VOID char -#endif - #include <sys/types.h> #if STDC_HEADERS # include <stdlib.h> #else -VOID *calloc (); -VOID *malloc (); -VOID *realloc (); +void *calloc (); +void *malloc (); +void *realloc (); void free (); #endif @@ -43,8 +37,10 @@ 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 @@ -52,16 +48,22 @@ void free (); /* 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); +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); #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; + +/* FIXME: describe */ +char *const xalloc_msg_memory_exhausted = N_("Memory exhausted"); + +/* FIXME: describe */ +void (*xalloc_fail_func) () = NULL; #if __STDC__ && (HAVE_VPRINTF || HAVE_DOPRNT) void error (int, int, const char *, ...); @@ -69,27 +71,31 @@ void error (int, int, const char *, ...); void error (); #endif -static VOID * +static void * fixup_null_alloc (n) size_t n; { - VOID *p; + void *p; p = 0; if (n == 0) p = malloc ((size_t) 1); if (p == 0) - error (xmalloc_exit_failure, 0, _("Memory exhausted")); + { + if (xalloc_fail_func) + (*xalloc_fail_func) (); + error (xalloc_exit_failure, 0, xalloc_msg_memory_exhausted); + } return p; } /* Allocate N bytes of memory dynamically, with error checking. */ -VOID * +void * xmalloc (n) size_t n; { - VOID *p; + void *p; p = malloc (n); if (p == 0) @@ -99,11 +105,11 @@ xmalloc (n) /* Allocate memory for N elements of S bytes, with error checking. */ -VOID * +void * xcalloc (n, s) size_t n, s; { - VOID *p; + void *p; p = calloc (n, s); if (p == 0) @@ -115,9 +121,9 @@ xcalloc (n, s) with error checking. If P is NULL, run xmalloc. */ -VOID * +void * xrealloc (p, n) - VOID *p; + void *p; size_t n; { if (p == 0) |