malloc.c 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. /* malloc() function that is glibc compatible.
  2. Copyright (C) 1997-1998, 2006-2007, 2009-2021 Free Software Foundation, Inc.
  3. This program is free software; you can redistribute it and/or modify
  4. it under the terms of the GNU General Public License as published by
  5. the Free Software Foundation; either version 3, or (at your option)
  6. any later version.
  7. This program is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. GNU General Public License for more details.
  11. You should have received a copy of the GNU General Public License
  12. along with this program; if not, see <https://www.gnu.org/licenses/>. */
  13. /* written by Jim Meyering and Bruno Haible */
  14. #define _GL_USE_STDLIB_ALLOC 1
  15. #include <config.h>
  16. /* Only the AC_FUNC_MALLOC macro defines 'malloc' already in config.h. */
  17. #ifdef malloc
  18. # define NEED_MALLOC_GNU 1
  19. # undef malloc
  20. /* Whereas the gnulib module 'malloc-gnu' defines HAVE_MALLOC_GNU. */
  21. #elif GNULIB_MALLOC_GNU && !HAVE_MALLOC_GNU
  22. # define NEED_MALLOC_GNU 1
  23. #endif
  24. #include <stdlib.h>
  25. #include <errno.h>
  26. /* Allocate an N-byte block of memory from the heap.
  27. If N is zero, allocate a 1-byte block. */
  28. void *
  29. rpl_malloc (size_t n)
  30. {
  31. void *result;
  32. #if NEED_MALLOC_GNU
  33. if (n == 0)
  34. n = 1;
  35. #endif
  36. result = malloc (n);
  37. #if !HAVE_MALLOC_POSIX
  38. if (result == NULL)
  39. errno = ENOMEM;
  40. #endif
  41. return result;
  42. }