1
0

last one i hope 😭

This commit is contained in:
Adam Joly
2023-12-15 05:51:46 +01:00
parent 7fcfc49a5a
commit f286a8aa54
6 changed files with 22 additions and 73 deletions

View File

@ -6,11 +6,12 @@
/* By: adjoly <adjoly@student.42.fr> +#+ +:+ +#+ */ /* By: adjoly <adjoly@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2023/12/01 17:11:59 by adjoly #+# #+# */ /* Created: 2023/12/01 17:11:59 by adjoly #+# #+# */
/* Updated: 2023/12/14 13:27:41 by adjoly ### ########.fr */ /* Updated: 2023/12/15 05:50:47 by adjoly ### ########.fr */
/* */ /* */
/* ************************************************************************** */ /* ************************************************************************** */
#include "get_next_line.h" #include "get_next_line.h"
#include <unistd.h>
char check_line(char *res, char *buf) char check_line(char *res, char *buf)
{ {
@ -37,8 +38,10 @@ char check_line(char *res, char *buf)
return (0); return (0);
} }
char *gnl_end_file(char *res) char *ft_read_error(char **buf, char *res)
{ {
free(*buf);
*buf = NULL;
if (res[0] != 0) if (res[0] != 0)
return (res); return (res);
free(res); free(res);
@ -53,40 +56,20 @@ char *get_next_line(int fd)
if (BUFFER_SIZE <= 0 || fd < 0 || fd > 1023) if (BUFFER_SIZE <= 0 || fd < 0 || fd > 1023)
return (NULL); return (NULL);
res = ft_calloc(1, 1);
if (!buf) if (!buf)
buf = ft_calloc(sizeof(char), BUFFER_SIZE + 1); buf = ft_calloc(sizeof(char), BUFFER_SIZE + 1);
while (buf && res) res = ft_calloc(1, 1);
while (buf)
{ {
res = ft_strjoin(res, buf); res = ft_strjoin(res, buf);
if (!res)
return (NULL);
if (check_line(res, buf)) if (check_line(res, buf))
return (res); return (res);
bytes_read = read(fd, buf, BUFFER_SIZE); bytes_read = read(fd, buf, BUFFER_SIZE);
if (bytes_read < 1) if (bytes_read < 1)
{ return (ft_read_error(&buf, res));
free(buf);
buf = NULL;
return (gnl_end_file(res));
}
buf[bytes_read] = 0; buf[bytes_read] = 0;
} }
return (NULL); return (NULL);
} }
/*#include <unistd.h>
void ft_putstr(char *str){if (str == NULL){return ;}int i = 0;while(str[i]){write(1, &str[i], 1);i++;}}
#include <fcntl.h>
#include <stdio.h>
int main(void)
{
char *ln;
int fd;
fd = open("test.txt", O_RDONLY);
while (ln)
{
ln = get_next_line(fd);
ft_putstr(ln);
free(ln);
}
close(fd);
}*/

View File

@ -6,7 +6,7 @@
/* By: adjoly <adjoly@student.42.fr> +#+ +:+ +#+ */ /* By: adjoly <adjoly@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2023/12/01 17:12:00 by adjoly #+# #+# */ /* Created: 2023/12/01 17:12:00 by adjoly #+# #+# */
/* Updated: 2023/12/08 18:01:49 by adjoly ### ########.fr */ /* Updated: 2023/12/15 05:43:13 by adjoly ### ########.fr */
/* */ /* */
/* ************************************************************************** */ /* ************************************************************************** */
@ -24,6 +24,5 @@ char *get_next_line(int fd);
char *ft_strjoin(char *s1, char *s2); char *ft_strjoin(char *s1, char *s2);
size_t ft_strlen(char *s); size_t ft_strlen(char *s);
void *ft_calloc(size_t nmemb, size_t size); void *ft_calloc(size_t nmemb, size_t size);
size_t ft_strlen_nl(char *s);
#endif #endif

View File

@ -6,7 +6,7 @@
/* By: adjoly <adjoly@student.42.fr> +#+ +:+ +#+ */ /* By: adjoly <adjoly@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2023/12/01 17:11:59 by adjoly #+# #+# */ /* Created: 2023/12/01 17:11:59 by adjoly #+# #+# */
/* Updated: 2023/12/14 13:27:45 by adjoly ### ########.fr */ /* Updated: 2023/12/15 05:51:22 by adjoly ### ########.fr */
/* */ /* */
/* ************************************************************************** */ /* ************************************************************************** */
@ -37,8 +37,10 @@ char check_line(char *res, char *buf)
return (0); return (0);
} }
char *gnl_end_line(char *res) char *ft_read_error(char **buf, char *res)
{ {
free(*buf);
*buf = NULL;
if (res[0] != 0) if (res[0] != 0)
return (res); return (res);
free(res); free(res);
@ -53,21 +55,19 @@ char *get_next_line(int fd)
if (BUFFER_SIZE <= 0 || fd < 0 || fd > 1023) if (BUFFER_SIZE <= 0 || fd < 0 || fd > 1023)
return (NULL); return (NULL);
res = ft_calloc(1, 1);
if (!buf[fd]) if (!buf[fd])
buf[fd] = ft_calloc(sizeof(char), BUFFER_SIZE + 1); buf[fd] = ft_calloc(sizeof(char), BUFFER_SIZE + 1);
res = ft_calloc(1, 1);
while (buf[fd] && res) while (buf[fd] && res)
{ {
res = ft_strjoin(res, buf[fd]); res = ft_strjoin(res, buf[fd]);
if (!res)
return (NULL);
if (check_line(res, buf[fd])) if (check_line(res, buf[fd]))
return (res); return (res);
bytes_read = read(fd, buf[fd], BUFFER_SIZE); bytes_read = read(fd, buf[fd], BUFFER_SIZE);
if (bytes_read < 1) if (bytes_read < 1)
{ return (ft_read_error(&buf[fd], res));
free(buf[fd]);
buf[fd] = NULL;
return (gnl_end_line(res));
}
buf[fd][bytes_read] = 0; buf[fd][bytes_read] = 0;
} }
return (NULL); return (NULL);

View File

@ -6,7 +6,7 @@
/* By: adjoly <adjoly@student.42.fr> +#+ +:+ +#+ */ /* By: adjoly <adjoly@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2023/12/01 17:12:00 by adjoly #+# #+# */ /* Created: 2023/12/01 17:12:00 by adjoly #+# #+# */
/* Updated: 2023/12/08 18:01:40 by adjoly ### ########.fr */ /* Updated: 2023/12/15 05:43:09 by adjoly ### ########.fr */
/* */ /* */
/* ************************************************************************** */ /* ************************************************************************** */
@ -24,6 +24,5 @@ char *get_next_line(int fd);
char *ft_strjoin(char *s1, char *s2); char *ft_strjoin(char *s1, char *s2);
size_t ft_strlen(char *s); size_t ft_strlen(char *s);
void *ft_calloc(size_t nmemb, size_t size); void *ft_calloc(size_t nmemb, size_t size);
size_t ft_strlen_nl(char *s);
#endif #endif

View File

@ -6,7 +6,7 @@
/* By: adjoly <adjoly@student.42.fr> +#+ +:+ +#+ */ /* By: adjoly <adjoly@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2023/12/01 17:12:02 by adjoly #+# #+# */ /* Created: 2023/12/01 17:12:02 by adjoly #+# #+# */
/* Updated: 2023/12/14 05:34:46 by adjoly ### ########.fr */ /* Updated: 2023/12/15 05:38:33 by adjoly ### ########.fr */
/* */ /* */
/* ************************************************************************** */ /* ************************************************************************** */
@ -51,22 +51,6 @@ char *ft_strjoin(char *s1, char *s2)
return (result); return (result);
} }
size_t ft_strlcpy(char *dst, char *src, size_t size)
{
size_t i;
i = 0;
if (size == 0)
return (ft_strlen(src));
while (i < size && src[i])
{
dst[i] = src[i];
i++;
}
dst[size] = '\0';
return (ft_strlen(src));
}
void *ft_calloc(size_t nmemb, size_t size) void *ft_calloc(size_t nmemb, size_t size)
{ {
char *result; char *result;

View File

@ -6,7 +6,7 @@
/* By: adjoly <adjoly@student.42.fr> +#+ +:+ +#+ */ /* By: adjoly <adjoly@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2023/12/01 17:12:02 by adjoly #+# #+# */ /* Created: 2023/12/01 17:12:02 by adjoly #+# #+# */
/* Updated: 2023/12/14 05:59:38 by adjoly ### ########.fr */ /* Updated: 2023/12/15 05:42:57 by adjoly ### ########.fr */
/* */ /* */
/* ************************************************************************** */ /* ************************************************************************** */
@ -51,22 +51,6 @@ char *ft_strjoin(char *s1, char *s2)
return (result); return (result);
} }
size_t ft_strlcpy(char *dst, char *src, size_t size)
{
size_t i;
i = 0;
if (size == 0)
return (ft_strlen(src));
while (i < size && src[i])
{
dst[i] = src[i];
i++;
}
dst[size] = '\0';
return (ft_strlen(src));
}
void *ft_calloc(size_t nmemb, size_t size) void *ft_calloc(size_t nmemb, size_t size)
{ {
char *result; char *result;