(root)/
m4-1.4.19/
tests/
test-reallocarray.c
       1  /* Test of reallocarray function.
       2     Copyright (C) 2010-2021 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 3 of the License, or
       7     (at your option) 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, see <https://www.gnu.org/licenses/>.  */
      16  
      17  #include <config.h>
      18  
      19  /* Specification.  */
      20  #include <stdlib.h>
      21  
      22  #include <errno.h>
      23  #include <stdint.h>
      24  
      25  #include "signature.h"
      26  SIGNATURE_CHECK (reallocarray, void *, (void *, size_t, size_t));
      27  
      28  #include "macros.h"
      29  
      30  int
      31  main ()
      32  {
      33    /* Check that reallocarray fails when requested to allocate a block
      34       of memory larger than PTRDIFF_MAX or SIZE_MAX bytes.  */
      35    for (size_t n = 2; n != 0; n <<= 1)
      36      {
      37        void *volatile p = NULL;
      38  
      39        p = reallocarray (p, PTRDIFF_MAX / n + 1, n);
      40        ASSERT (p == NULL);
      41        ASSERT (errno == ENOMEM);
      42  
      43        p = reallocarray (p, SIZE_MAX / n + 1, n);
      44        ASSERT (p == NULL);
      45        ASSERT (errno == ENOMEM
      46                || errno == EOVERFLOW /* NetBSD */);
      47  
      48        /* Reallocarray should not crash with zero sizes.  */
      49        p = reallocarray (p, 0, n);
      50        p = reallocarray (p, n, 0);
      51        free (p);
      52      }
      53  
      54    return 0;
      55  }