Use "exit.h" rather than rolling EXIT_FAILURE ourselves in each module.
[gnulib.git] / lib / xmalloc.c
1 /* xmalloc.c -- malloc with out of memory checking
2
3    Copyright (C) 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
4    1999, 2000, 2002, 2003 Free Software Foundation, Inc.
5
6    This program is free software; you can redistribute it and/or modify
7    it under the terms of the GNU General Public License as published by
8    the Free Software Foundation; either version 2, or (at your option)
9    any later version.
10
11    This program is distributed in the hope that it will be useful,
12    but WITHOUT ANY WARRANTY; without even the implied warranty of
13    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14    GNU General Public License for more details.
15
16    You should have received a copy of the GNU General Public License
17    along with this program; if not, write to the Free Software Foundation,
18    Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
19
20 #if HAVE_CONFIG_H
21 # include <config.h>
22 #endif
23
24 #include "xalloc.h"
25
26 #include <stdlib.h>
27
28 #include "gettext.h"
29 #define _(msgid) gettext (msgid)
30 #define N_(msgid) msgid
31
32 #include "error.h"
33 #include "exit.h"
34 #include "exitfail.h"
35
36 /* The following tests require AC_PREREQ(2.54).  */
37
38 #ifndef HAVE_MALLOC
39 "you must run the autoconf test for a GNU libc compatible malloc"
40 #endif
41
42 #ifndef HAVE_REALLOC
43 "you must run the autoconf test for a GNU libc compatible realloc"
44 #endif
45
46 /* If non NULL, call this function when memory is exhausted. */
47 void (*xalloc_fail_func) (void) = 0;
48
49 /* If XALLOC_FAIL_FUNC is NULL, or does return, display this message
50    before exiting when memory is exhausted.  Goes through gettext. */
51 char const xalloc_msg_memory_exhausted[] = N_("memory exhausted");
52
53 void
54 xalloc_die (void)
55 {
56   if (xalloc_fail_func)
57     (*xalloc_fail_func) ();
58   error (exit_failure, 0, "%s", _(xalloc_msg_memory_exhausted));
59   /* The `noreturn' cannot be given to error, since it may return if
60      its first argument is 0.  To help compilers understand the
61      xalloc_die does terminate, call exit. */
62   exit (EXIT_FAILURE);
63 }
64
65 /* Allocate N bytes of memory dynamically, with error checking.  */
66
67 void *
68 xmalloc (size_t n)
69 {
70   void *p;
71
72   p = malloc (n);
73   if (p == 0)
74     xalloc_die ();
75   return p;
76 }
77
78 /* Change the size of an allocated block of memory P to N bytes,
79    with error checking.  */
80
81 void *
82 xrealloc (void *p, size_t n)
83 {
84   p = realloc (p, n);
85   if (p == 0)
86     xalloc_die ();
87   return p;
88 }
89
90 /* Allocate memory for N elements of S bytes, with error checking.  */
91
92 void *
93 xcalloc (size_t n, size_t s)
94 {
95   void *p;
96
97   p = calloc (n, s);
98   if (p == 0)
99     xalloc_die ();
100   return p;
101 }