From bbf855f5a027f8b92eeebe0e3f7a579a7f420771 Mon Sep 17 00:00:00 2001 From: Charles Date: Sun, 25 Aug 2019 20:53:54 +0200 Subject: add ft_memcpy --- get_next_line.c | 41 +++++++++++++++++++++++++++++++++++++---- get_next_line.h | 1 - 2 files changed, 37 insertions(+), 5 deletions(-) diff --git a/get_next_line.c b/get_next_line.c index 0beef4d..a5c2288 100644 --- a/get_next_line.c +++ b/get_next_line.c @@ -1,14 +1,47 @@ #include #include +#include "libft.h" #include "get_next_line.h" +static unsigned int cursor; + +static void *ft_memcat(void *ptr, void *tail, + unsigned int size, unsigned int tail_size); + int get_next_line(const int fd, char **line) { - char buf[BUFF_SIZE]; + unsigned int newline_i; + char buf[BUFF_SIZE]; - while ((read(fd, buf, BUFF_SIZE)) > 0) + if (read(fd, buf, BUFF_SIZE) < 0) + return (-1); + if ((*line = ft_strnew(0)) == NULL) + return (-1); + newline_i = 0; + while (buf[newline_i]) { - + while (buf[newline_i] != '\n') + newline_i++; + ft_memcat(*line, buf, 0, newline_i); + if (read(fd, buf, BUFF_SIZE) < 0) + return (-1); } - return 0; + return (0); +} + +static void *ft_memcat(void *ptr, void *tail, + unsigned int size, unsigned int tail_size) +{ + void *copy; + + if ((copy = malloc(size)) == NULL) + return (NULL); + ft_memcpy(copy, ptr, size); + free(ptr); + if ((ptr = malloc(size + tail_size)) == NULL) + return (NULL); + ft_memcpy(ptr, copy, size); + free(copy); + ft_memcpy(ptr + size, tail, tail_size); + return (ptr); } diff --git a/get_next_line.h b/get_next_line.h index efe927b..a70ea24 100644 --- a/get_next_line.h +++ b/get_next_line.h @@ -1,7 +1,6 @@ #ifndef GET_NEXT_LINE_H # define GET_NEXT_LINE_H -# define NEWLINE 0x0A # define BUFF_SIZE (1 << 8) int get_next_line(const int fd, char **line); -- cgit