ft_calloc: initial implementation

This commit is contained in:
Khaïs COLIN 2024-10-17 10:42:43 +02:00
parent fce032ce2f
commit a38e9e5f94
3 changed files with 52 additions and 3 deletions

View file

@ -6,7 +6,7 @@
# By: kcolin <marvin@42.fr> +#+ +:+ +#+ # # By: kcolin <marvin@42.fr> +#+ +:+ +#+ #
# +#+#+#+#+#+ +#+ # # +#+#+#+#+#+ +#+ #
# Created: 2024/10/14 13:43:59 by kcolin #+# #+# # # Created: 2024/10/14 13:43:59 by kcolin #+# #+# #
# Updated: 2024/10/16 16:02:21 by kcolin ### ########.fr # # Updated: 2024/10/17 10:21:34 by kcolin ### ########.fr #
# # # #
# **************************************************************************** # # **************************************************************************** #
@ -32,7 +32,8 @@ SOURCES = ft_isalpha.c \
ft_memchr.c \ ft_memchr.c \
ft_memcmp.c \ ft_memcmp.c \
ft_strnstr.c \ ft_strnstr.c \
ft_atoi.c ft_atoi.c \
ft_calloc.c
OBJECTS = $(SOURCES:.c=.o) OBJECTS = $(SOURCES:.c=.o)
CC = gcc CC = gcc

46
ft_calloc.c Normal file
View file

@ -0,0 +1,46 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* ft_calloc.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: kcolin <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/10/17 10:20:05 by kcolin #+# #+# */
/* Updated: 2024/10/17 10:40:21 by kcolin ### ########.fr */
/* */
/* ************************************************************************** */
#include "libft.h"
#include <stdlib.h>
void *ft_calloc(size_t nmemb, size_t size)
{
size_t bytes;
bytes = nmemb * size;
if (nmemb != 0 && bytes / nmemb != size)
return (NULL);
else
return (malloc(bytes));
}
/*
int main(void)
{
free(ft_calloc(0, sizeof(int)));
free(calloc(0, sizeof(int)));
printf("%p\t%p\n",
ft_calloc(0, sizeof(int)),
calloc(0, sizeof(int)));
free(ft_calloc(1024, sizeof(int)));
free(calloc(1024, sizeof(int)));
printf("%p\t%p\n",
ft_calloc(1024, sizeof(int)),
calloc(1024, sizeof(int)));
free(ft_calloc(SIZE_MAX, sizeof(int)));
free(calloc(SIZE_MAX, sizeof(int)));
printf("%p\t%p\n",
ft_calloc(SIZE_MAX, sizeof(int)),
calloc(SIZE_MAX, sizeof(int)));
}
*/

View file

@ -6,7 +6,7 @@
/* By: kcolin <marvin@42.fr> +#+ +:+ +#+ */ /* By: kcolin <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2024/10/15 10:11:54 by kcolin #+# #+# */ /* Created: 2024/10/15 10:11:54 by kcolin #+# #+# */
/* Updated: 2024/10/16 16:06:06 by kcolin ### ########.fr */ /* Updated: 2024/10/17 10:19:51 by kcolin ### ########.fr */
/* */ /* */
/* ************************************************************************** */ /* ************************************************************************** */
@ -44,4 +44,6 @@ char *ft_strnstr(const char *big, const char *little, size_t len);
int ft_atoi(const char *nptr); int ft_atoi(const char *nptr);
void *ft_calloc(size_t nmemb, size_t size);
#endif #endif