Compare commits

...

10 commits

Author SHA1 Message Date
Raphael
ee27ca6db6
feat(bonus): replacing mandatory header by bonus header 2026-01-29 14:28:00 +01:00
Raphael
c2f5d7e592
feat(bonus): replacing mandatory header by bonus header 2026-01-29 14:27:57 +01:00
Raphael
20a44fbef3
feat(gnl/bonus): adding open_max define 2026-01-29 14:27:11 +01:00
Raphael
250f632f6d
feat(bonus): adding the bonus header 2025-12-21 00:19:46 +01:00
Raphael
50164d52ad
feat(bonus): adding the bonus sources 2025-12-21 00:19:33 +01:00
Raphael
9dd2216fa5
style: Changing the strchr to strchr_index 2025-12-21 00:19:07 +01:00
Raphael
e166b48698
feat: removing the file_converted 2025-12-21 00:19:00 +01:00
Raphael
4334807521
style: Changing the strchr to strchr_index 2025-12-21 00:18:49 +01:00
Raphael
00f9484dc4
feat: removing the file_converted 2025-12-21 00:18:31 +01:00
Raphael
8445a8c956
style: Changing the strchr to strchr_index 2025-12-21 00:18:11 +01:00
6 changed files with 217 additions and 30 deletions

View file

@ -6,7 +6,7 @@
/* By: rparodi <marvin@42.fr> +#+ +:+ +#+ */ /* By: rparodi <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2023/11/18 17:12:02 by rparodi #+# #+# */ /* Created: 2023/11/18 17:12:02 by rparodi #+# #+# */
/* Updated: 2023/11/22 13:31:13 by rparodi ### ########.fr */ /* Updated: 2025/12/20 23:59:09 by rparodi ### ########.fr */
/* */ /* */
/* ************************************************************************** */ /* ************************************************************************** */
@ -21,7 +21,7 @@ char *ft_check(char *memory, int fd)
buffer = (char *)malloc(sizeof(char) * (BUFFER_SIZE + 1)); buffer = (char *)malloc(sizeof(char) * (BUFFER_SIZE + 1));
if (!buffer) if (!buffer)
return (NULL); return (NULL);
while (ft_strchr(memory, '\n') <= 0 && bytescopy) while (ft_strchr_index(memory, '\n') <= 0 && bytescopy)
{ {
bytescopy = read(fd, buffer, BUFFER_SIZE); bytescopy = read(fd, buffer, BUFFER_SIZE);
if (bytescopy == -1) if (bytescopy == -1)
@ -33,29 +33,6 @@ char *ft_check(char *memory, int fd)
return (memory); return (memory);
} }
char *file_converted(int fd)
{
size_t i;
int read_bits;
char *str;
char c;
i = 0;
c = 1;
read_bits = 1;
str = (char *)malloc(sizeof(char) * BUFFER_SIZE);
if (!str)
return (NULL);
while (read_bits != 0 && i < BUFFER_SIZE)
{
read_bits = read(fd, &c, 1);
str[i] = c;
i++;
}
str[i] = '\0';
return (str);
}
char *ft_free(char *str) char *ft_free(char *str)
{ {
free(str); free(str);

View file

@ -6,7 +6,7 @@
/* By: rparodi <marvin@42.fr> +#+ +:+ +#+ */ /* By: rparodi <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2023/11/18 17:12:04 by rparodi #+# #+# */ /* Created: 2023/11/18 17:12:04 by rparodi #+# #+# */
/* Updated: 2023/11/23 18:15:34 by rparodi ### ########.fr */ /* Updated: 2025/12/20 23:59:36 by rparodi ### ########.fr */
/* */ /* */
/* ************************************************************************** */ /* ************************************************************************** */
@ -21,12 +21,11 @@
char *ft_get_line(char *str); char *ft_get_line(char *str);
char *get_next_line(int fd); char *get_next_line(int fd);
int ft_strchr(char *str, char c); int ft_strchr_index(char *str, char c);
char *ft_get_next(char *str); char *ft_get_next(char *str);
char *ft_get_line(char *str); char *ft_get_line(char *str);
char *ft_strjoin(char *s1, char *s2, int i, int j); char *ft_strjoin(char *s1, char *s2, int i, int j);
size_t ft_strlen(char const *str); size_t ft_strlen(char const *str);
char *file_converted(int fd);
char *ft_free(char *str); char *ft_free(char *str);
char *ft_check(char *memory, int fd); char *ft_check(char *memory, int fd);

55
get_next_line_bonus.c Normal file
View file

@ -0,0 +1,55 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* get_next_line_bonus.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: rparodi <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2023/11/18 17:12:02 by rparodi #+# #+# */
/* Updated: 2026/01/29 14:25:47 by rparodi ### ########.fr */
/* */
/* ************************************************************************** */
#include "get_next_line_bonus.h"
char *ft_check(char *memory, int fd)
{
char *buffer;
int bytescopy;
bytescopy = 1;
buffer = (char *)malloc(sizeof(char) * (BUFFER_SIZE + 1));
if (!buffer)
return (NULL);
while (ft_strchr_index(memory, '\n') <= 0 && bytescopy)
{
bytescopy = read(fd, buffer, BUFFER_SIZE);
if (bytescopy == -1)
return (ft_free(buffer));
buffer[bytescopy] = '\0';
memory = ft_strjoin(memory, buffer, 0, -1);
}
free(buffer);
return (memory);
}
char *ft_free(char *str)
{
free(str);
return (NULL);
}
char *get_next_line(int fd)
{
static char *memory[OPEN_MAX] = { 0 };
char *line;
if (fd < 0 || fd >= OPEN_MAX || BUFFER_SIZE <= 0)
return (NULL);
memory[fd] = ft_check(memory[fd], fd);
if (!memory[fd])
return (ft_free(memory[fd]));
line = ft_get_line(memory[fd]);
memory[fd] = ft_get_next(memory[fd]);
return (line);
}

37
get_next_line_bonus.h Normal file
View file

@ -0,0 +1,37 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* get_next_line_bonus.h :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: rparodi <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2023/11/18 17:12:04 by rparodi #+# #+# */
/* Updated: 2026/01/29 14:24:48 by rparodi ### ########.fr */
/* */
/* ************************************************************************** */
#ifndef GET_NEXT_LINE_BONUS_H
# define GET_NEXT_LINE_BONUS_H
# ifndef BUFFER_SIZE
# define BUFFER_SIZE 420
# endif
# ifndef OPEN_MAX
# define OPEN_MAX 1024
# endif
# include <unistd.h>
# include <stdlib.h>
char *ft_get_line(char *str);
char *get_next_line(int fd);
int ft_strchr_index(char *str, char c);
char *ft_get_next(char *str);
char *ft_get_line(char *str);
char *ft_strjoin(char *s1, char *s2, int i, int j);
size_t ft_strlen(char const *str);
char *ft_free(char *str);
char *ft_check(char *memory, int fd);
#endif

View file

@ -6,7 +6,7 @@
/* By: rparodi <marvin@42.fr> +#+ +:+ +#+ */ /* By: rparodi <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */ /* +#+#+#+#+#+ +#+ */
/* Created: 2023/11/18 17:14:47 by rparodi #+# #+# */ /* Created: 2023/11/18 17:14:47 by rparodi #+# #+# */
/* Updated: 2023/11/22 13:35:03 by rparodi ### ########.fr */ /* Updated: 2025/12/20 23:59:24 by rparodi ### ########.fr */
/* */ /* */
/* ************************************************************************** */ /* ************************************************************************** */
@ -101,7 +101,7 @@ char *ft_get_next(char *str)
return (temp); return (temp);
} }
int ft_strchr(char *str, char c) int ft_strchr_index(char *str, char c)
{ {
int i; int i;

119
get_next_line_utils_bonus.c Normal file
View file

@ -0,0 +1,119 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* get_next_line_utils_bonus.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: rparodi <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2023/11/18 17:14:47 by rparodi #+# #+# */
/* Updated: 2026/01/29 14:26:18 by rparodi ### ########.fr */
/* */
/* ************************************************************************** */
#include "get_next_line_bonus.h"
size_t ft_strlen(char const *str)
{
size_t i;
i = 0;
if (str)
{
while (str[i])
i++;
}
return (i);
}
char *ft_strjoin(char *s1, char *s2, int i, int j)
{
char *temp;
if (!s1)
{
s1 = (char *)malloc(1);
s1[i] = '\0';
}
if (!s2 || !s1)
return (NULL);
temp = (char *)malloc((ft_strlen(s1) + ft_strlen(s2) + 1));
if (!temp)
return (NULL);
while (s1[i])
{
temp[i] = s1[i];
i++;
}
while (s2[++j])
temp[i + j] = s2[j];
temp[i + j] = '\0';
free(s1);
return (temp);
}
char *ft_get_line(char *str)
{
char *temp;
int i;
i = 0;
if (!str[i])
return (NULL);
while (str[i] && str[i] != '\n')
i++;
temp = (char *)malloc((i + 2));
if (!temp)
return (NULL);
i = 0;
while (str[i] && str[i] != '\n')
{
temp[i] = str[i];
i++;
}
if (str[i] == '\n')
{
temp[i] = str[i];
i++;
}
temp[i] = '\0';
return (temp);
}
char *ft_get_next(char *str)
{
char *temp;
int i;
int j;
i = 0;
while (str[i] && str[i] != '\n')
i++;
if (!str[i])
return (ft_free(str));
temp = (char *)malloc((ft_strlen(str) - i));
if (!temp)
return (NULL);
j = i + 1;
while (str[++i])
temp[i - j] = str[i];
temp[i - j] = '\0';
free(str);
return (temp);
}
int ft_strchr_index(char *str, char c)
{
int i;
i = 0;
if (str)
{
while (str[i])
{
if (str[i] == c)
return (i);
i++;
}
}
return (-1);
}