This commit is contained in:
Camille Chauvet 2022-11-08 14:49:12 +01:00
parent 386bef0a64
commit d4f57e8f7b
6 changed files with 56 additions and 63 deletions

View File

@ -6,7 +6,7 @@
/* By: cchauvet <cchauvet@student.42angoulem +#+ +:+ +#+ */ /* By: cchauvet <cchauvet@student.42angoulem +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2022/10/26 00:52:47 by cchauvet #+# #+# */ /* Created: 2022/10/26 00:52:47 by cchauvet #+# #+# */
/* Updated: 2022/10/28 13:37:18 by cchauvet ### ########.fr */ /* Updated: 2022/10/28 16:01:01 by cchauvet ### ########.fr */
/* */ /* */
/* ************************************************************************** */ /* ************************************************************************** */
@ -21,7 +21,7 @@ char *ft_getstash(int fd)
if (str == NULL) if (str == NULL)
return (NULL); return (NULL);
readed = read(fd, str, BUFFER_SIZE); readed = read(fd, str, BUFFER_SIZE);
if (readed < 0) if (readed < 1)
{ {
free(str); free(str);
return (NULL); return (NULL);
@ -29,40 +29,18 @@ char *ft_getstash(int fd)
return (str); return (str);
} }
ssize_t ft_strchr(char *str, char c)
{
size_t i;
if (str == NULL)
return (-1);
i = 0;
while (str[i] != c && str[i] != '\0')
i++;
if (str[i] == '\0')
return (-1);
return (i);
}
char *ft_getline(int fd) char *ft_getline(int fd)
{ {
char *stash; char *stash;
char *buf; char *buf;
size_t i;
stash = NULL; stash = NULL;
buf = NULL; buf = NULL;
i = 0; while (ft_strchr(stash, '\n') == -1)
while (ft_strchr(stash + i, '\n') == -1)
{ {
i = i + ft_strlen(buf);
buf = ft_getstash(fd); buf = ft_getstash(fd);
if (buf == NULL) if (buf == NULL)
return (NULL); return (stash);
if (buf[0] == '\0')
{
free(buf);
break ;
}
stash = ft_strfjoin(stash, buf); stash = ft_strfjoin(stash, buf);
if (stash == NULL) if (stash == NULL)
return (NULL); return (NULL);
@ -70,6 +48,32 @@ char *ft_getline(int fd)
return (stash); return (stash);
} }
char *ft_getreturn(char *str)
{
int i;
if (str == NULL)
return (NULL);
i = ft_strchr(str, '\n') + 1;
if (i == 0)
i = ft_strlen(str);
return(ft_strndup(str, i));
}
char *ft_getextra(char *str)
{
int i;
int j;
if (str == NULL)
return (NULL);
i = ft_strchr(str, '\n') + 1;
if (i == 0)
return (NULL);
j = ft_strlen(str + i);
return(ft_strndup(str + i, j));
}
char *get_next_line(int fd) char *get_next_line(int fd)
{ {
static char *stash = NULL; static char *stash = NULL;
@ -80,16 +84,17 @@ char *get_next_line(int fd)
if (ft_strchr(stash, '\n') == -1) if (ft_strchr(stash, '\n') == -1)
{ {
buf1 = ft_getline(fd); buf1 = ft_getline(fd);
if (buf1 == NULL)
return (NULL);
buf2 = ft_strfjoin(stash, buf1); buf2 = ft_strfjoin(stash, buf1);
if (buf2 == NULL) if (buf2 == NULL)
{
free(buf1);
return (NULL); return (NULL);
}
} }
buf1 = ft_strndup(buf2, ft_strchr(buf2, '\n') + 1); buf1 = ft_getreturn(buf2);
stash = ft_strndup(buf2 + ft_strchr(buf2, '\n') + 1, ft_strlen(buf2)); stash = ft_getextra(buf2);
free(buf2); free(buf2);
if (stash == NULL || buf1 == NULL) if (buf1 == NULL)
{ {
free(stash); free(stash);
free(buf1); free(buf1);

View File

@ -3,12 +3,13 @@
# include <stdlib.h> # include <stdlib.h>
# include <unistd.h> # include <unistd.h>
# define BUFFER_SIZE 10 //# define BUFFER_SIZE 40
void *ft_calloc(size_t nmemb, size_t size); void *ft_calloc(size_t nmemb, size_t size);
void *ft_realloc(void *ptr, size_t size); void *ft_realloc(void *ptr, size_t size);
char *ft_strfjoin(char *dst, char *src); char *ft_strfjoin(char *dst, char *src);
char *ft_strndup(char *src, size_t n); char *ft_strndup(char *src, size_t n);
size_t ft_strlen(char *str); size_t ft_strlen(char *str);
ssize_t ft_strchr(char *str, char c);
char *get_next_line(int fd); char *get_next_line(int fd);
#endif #endif

View File

@ -6,7 +6,7 @@
/* By: cchauvet <cchauvet@student.42angoulem +#+ +:+ +#+ */ /* By: cchauvet <cchauvet@student.42angoulem +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2022/10/26 00:55:44 by cchauvet #+# #+# */ /* Created: 2022/10/26 00:55:44 by cchauvet #+# #+# */
/* Updated: 2022/10/26 23:55:03 by cchauvet ### ########.fr */ /* Updated: 2022/10/28 14:38:10 by cchauvet ### ########.fr */
/* */ /* */
/* ************************************************************************** */ /* ************************************************************************** */
@ -79,6 +79,8 @@ char *ft_strndup(char *src, size_t n)
char *out; char *out;
size_t i; size_t i;
if (src[0] == '\0')
return (NULL);
out = ft_calloc(n + 1, sizeof(char)); out = ft_calloc(n + 1, sizeof(char));
if (out == NULL) if (out == NULL)
return (NULL); return (NULL);
@ -90,3 +92,18 @@ char *ft_strndup(char *src, size_t n)
} }
return (out); return (out);
} }
ssize_t ft_strchr(char *str, char c)
{
size_t i;
if (str == NULL)
return (-1);
i = 0;
while (str[i] != c && str[i] != '\0')
i++;
if (str[i] == '\0')
return (-1);
return (i);
}

@ -1 +0,0 @@
Subproject commit 2e28a6ce9454666c6670645a60a1b9b4404d0c65

26
main.c
View File

@ -1,26 +0,0 @@
#include "get_next_line.h"
#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
int main(void)
{
int fd = open("tester", O_RDONLY);
char *str;
str = get_next_line(fd);
printf("%s", str);
free(str);
str = get_next_line(fd);
printf("%s", str);
free(str);
str = get_next_line(fd);
printf("%s", str);
free(str);
// printf("%s", get_next_line(fd));
// printf("%s", get_next_line(fd));
// printf("%s", get_next_line(fd));
// printf("%s", get_next_line(fd));
// printf("%s", get_next_line(fd));
}

3
tester
View File

@ -1,3 +0,0 @@
test1
test2
test3