last one i hope 😭
This commit is contained in:
@ -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);
|
|
||||||
}*/
|
|
||||||
|
@ -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
|
@ -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);
|
||||||
|
@ -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
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
Reference in New Issue
Block a user