fix all issues
This commit is contained in:
28
ft_split.c
28
ft_split.c
@@ -6,13 +6,13 @@
|
|||||||
/* By: dgaillet <dgaillet@student.42.fr> +#+ +:+ +#+ */
|
/* By: dgaillet <dgaillet@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2025/11/06 17:02:58 by dgaillet #+# #+# */
|
/* Created: 2025/11/06 17:02:58 by dgaillet #+# #+# */
|
||||||
/* Updated: 2025/11/07 13:05:00 by dgaillet ### ########lyon.fr */
|
/* Updated: 2025/11/09 20:29:25 by dgaillet ### ########lyon.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
#include "libft.h"
|
#include "libft.h"
|
||||||
|
|
||||||
size_t strs_size(const char *s, char c)
|
static size_t strs_size(const char *s, unsigned char c)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
int j;
|
int j;
|
||||||
@@ -28,7 +28,7 @@ size_t strs_size(const char *s, char c)
|
|||||||
return (i);
|
return (i);
|
||||||
}
|
}
|
||||||
|
|
||||||
int next_match(char *str, char c)
|
static int next_match(char *str, unsigned char c)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
@@ -38,15 +38,28 @@ int next_match(char *str, char c)
|
|||||||
return (i);
|
return (i);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void clear_strs(char **strs)
|
||||||
|
{
|
||||||
|
size_t i;
|
||||||
|
|
||||||
|
i = 0;
|
||||||
|
while (strs[i])
|
||||||
|
{
|
||||||
|
free(strs[i]);
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
free(strs);
|
||||||
|
}
|
||||||
|
|
||||||
char **ft_split(char const *s, char c)
|
char **ft_split(char const *s, char c)
|
||||||
{
|
{
|
||||||
char **strs;
|
char **strs;
|
||||||
int i;
|
int i;
|
||||||
int j;
|
int j;
|
||||||
|
|
||||||
strs = malloc(sizeof(char *) * (strs_size(s, c) + 1));
|
strs = ft_calloc(sizeof(char *), strs_size(s, c) + 1);
|
||||||
if (!strs)
|
if (!strs)
|
||||||
return (free(strs), NULL);
|
return (NULL);
|
||||||
i = 0;
|
i = 0;
|
||||||
j = 0;
|
j = 0;
|
||||||
while (s[j])
|
while (s[j])
|
||||||
@@ -56,11 +69,12 @@ char **ft_split(char const *s, char c)
|
|||||||
if (s[j] == c)
|
if (s[j] == c)
|
||||||
j++;
|
j++;
|
||||||
strs[i] = ft_substr(&s[j], 0, next_match((char *) &s[j], c));
|
strs[i] = ft_substr(&s[j], 0, next_match((char *) &s[j], c));
|
||||||
|
if (!strs[i])
|
||||||
|
return (clear_strs(strs), NULL);
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
j++;
|
j++;
|
||||||
}
|
}
|
||||||
strs[i] = NULL;
|
|
||||||
return (strs);
|
return (strs);
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
@@ -71,7 +85,7 @@ int main(void)
|
|||||||
char **strs;
|
char **strs;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
strs = ft_split("awdawdawd", ' ');
|
strs = ft_split("--1-2--3---4----5-----42", ' ');
|
||||||
i = 0;
|
i = 0;
|
||||||
while (strs[i])
|
while (strs[i])
|
||||||
{
|
{
|
||||||
|
|||||||
Reference in New Issue
Block a user