New module 'calloc-posix'.
[pspp] / lib / calloc.c
1 /* calloc() function that is glibc compatible.
2    This wrapper function is required at least on Tru64 UNIX 5.1 and mingw.
3    Copyright (C) 2004, 2005, 2006, 2007 Free Software Foundation, Inc.
4
5    This program is free software; you can redistribute it and/or modify
6    it under the terms of the GNU General Public License as published by
7    the Free Software Foundation; either version 2, or (at your option)
8    any later version.
9
10    This program is distributed in the hope that it will be useful,
11    but WITHOUT ANY WARRANTY; without even the implied warranty of
12    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13    GNU General Public License for more details.
14
15    You should have received a copy of the GNU General Public License
16    along with this program; if not, write to the Free Software Foundation,
17    Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.  */
18
19 /* written by Jim Meyering and Bruno Haible */
20
21 #include <config.h>
22 /* Only the AC_FUNC_CALLOC macro defines 'calloc' already in config.h.  */
23 #ifdef calloc
24 # define NEED_CALLOC_GNU
25 # undef calloc
26 #endif
27
28 /* Specification.  */
29 #include <stdlib.h>
30
31 #include <errno.h>
32
33 /* Allocate and zero-fill an NxS-byte block of memory from the heap.
34    If N or S is zero, allocate and zero-fill a 1-byte block.  */
35
36 void *
37 rpl_calloc (size_t n, size_t s)
38 {
39   void *result;
40
41 #ifdef NEED_CALLOC_GNU
42   if (n == 0 || s == 0)
43     {
44       n = 1;
45       s = 1;
46     }
47   else
48     {
49       /* Defend against buggy calloc implementations that mishandle
50          size_t overflow.  */
51       size_t bytes = n * s;
52       if (bytes / s != n)
53         {
54           errno = ENOMEM;
55           return NULL;
56         }
57     }
58 #endif
59
60   result = calloc (n, s);
61
62 #if !HAVE_CALLOC_POSIX
63   if (result == NULL)
64     errno = ENOMEM;
65 #endif
66
67   return result;
68 }