Include xalloc.h.
[pspp] / lib / xmalloc.c
1 /* xmalloc.c -- malloc with out of memory checking
2    Copyright (C) 1990, 91, 92, 93, 94, 95, 96, 97 Free Software Foundation, Inc.
3
4    This program is free software; you can redistribute it and/or modify
5    it under the terms of the GNU General Public License as published by
6    the Free Software Foundation; either version 2, or (at your option)
7    any later version.
8
9    This program is distributed in the hope that it will be useful,
10    but WITHOUT ANY WARRANTY; without even the implied warranty of
11    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12    GNU General Public License for more details.
13
14    You should have received a copy of the GNU General Public License
15    along with this program; if not, write to the Free Software Foundation,
16    Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
17
18 #if HAVE_CONFIG_H
19 # include <config.h>
20 #endif
21
22 #include <sys/types.h>
23
24 #if STDC_HEADERS
25 # include <stdlib.h>
26 #else
27 void *calloc ();
28 void *malloc ();
29 void *realloc ();
30 void free ();
31 #endif
32
33 #if ENABLE_NLS
34 # include <libintl.h>
35 # define _(Text) gettext (Text)
36 #else
37 # define textdomain(Domain)
38 # define _(Text) Text
39 #endif
40 #define N_(Text) Text
41
42 #include "error.h"
43 #include "xalloc.h"
44
45 #ifndef EXIT_FAILURE
46 # define EXIT_FAILURE 1
47 #endif
48
49 /* Prototypes for functions defined here.  */
50 #if defined (__STDC__) && __STDC__
51 static void *fixup_null_alloc (size_t n);
52 void *xmalloc (size_t n);
53 void *xcalloc (size_t n, size_t s);
54 void *xrealloc (void *p, size_t n);
55 #endif
56
57
58 /* Exit value when the requested amount of memory is not available.
59    The caller may set it to some other value.  */
60 int xalloc_exit_failure = EXIT_FAILURE;
61
62 /* FIXME: describe */
63 char *const xalloc_msg_memory_exhausted = N_("Memory exhausted");
64
65 /* FIXME: describe */
66 void (*xalloc_fail_func) () = NULL;
67
68 #if __STDC__ && (HAVE_VPRINTF || HAVE_DOPRNT)
69 void error (int, int, const char *, ...);
70 #else
71 void error ();
72 #endif
73
74 static void *
75 fixup_null_alloc (n)
76      size_t n;
77 {
78   void *p;
79
80   p = 0;
81   if (n == 0)
82     p = malloc ((size_t) 1);
83   if (p == 0)
84     {
85       if (xalloc_fail_func)
86         (*xalloc_fail_func) ();
87       error (xalloc_exit_failure, 0, xalloc_msg_memory_exhausted);
88     }
89   return p;
90 }
91
92 /* Allocate N bytes of memory dynamically, with error checking.  */
93
94 void *
95 xmalloc (n)
96      size_t n;
97 {
98   void *p;
99
100   p = malloc (n);
101   if (p == 0)
102     p = fixup_null_alloc (n);
103   return p;
104 }
105
106 /* Allocate memory for N elements of S bytes, with error checking.  */
107
108 void *
109 xcalloc (n, s)
110      size_t n, s;
111 {
112   void *p;
113
114   p = calloc (n, s);
115   if (p == 0)
116     p = fixup_null_alloc (n);
117   return p;
118 }
119
120 /* Change the size of an allocated block of memory P to N bytes,
121    with error checking.
122    If P is NULL, run xmalloc.  */
123
124 void *
125 xrealloc (p, n)
126      void *p;
127      size_t n;
128 {
129   if (p == 0)
130     return xmalloc (n);
131   p = realloc (p, n);
132   if (p == 0)
133     p = fixup_null_alloc (n);
134   return p;
135 }