Oops, avoid an infinite recursion.
[gnulib.git] / 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 /* Call the system's calloc below.  */
34 #undef calloc
35
36 /* Allocate and zero-fill an NxS-byte block of memory from the heap.
37    If N or S is zero, allocate and zero-fill a 1-byte block.  */
38
39 void *
40 rpl_calloc (size_t n, size_t s)
41 {
42   void *result;
43
44 #ifdef NEED_CALLOC_GNU
45   if (n == 0 || s == 0)
46     {
47       n = 1;
48       s = 1;
49     }
50   else
51     {
52       /* Defend against buggy calloc implementations that mishandle
53          size_t overflow.  */
54       size_t bytes = n * s;
55       if (bytes / s != n)
56         {
57           errno = ENOMEM;
58           return NULL;
59         }
60     }
61 #endif
62
63   result = calloc (n, s);
64
65 #if !HAVE_CALLOC_POSIX
66   if (result == NULL)
67     errno = ENOMEM;
68 #endif
69
70   return result;
71 }