1
0
libft_new/str/ft_split.c

95 lines
2.0 KiB
C
Raw Permalink Normal View History

2023-11-10 18:49:34 +01:00
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* ft_split.c :+: :+: :+: */
/* +:+ +:+ +:+ */
2024-02-04 15:11:02 +01:00
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
2023-11-10 18:49:34 +01:00
/* +#+#+#+#+#+ +#+ */
2023-11-12 09:18:34 +01:00
/* Created: 2023/11/12 09:14:19 by adjoly #+# #+# */
2024-02-04 15:11:02 +01:00
/* Updated: 2024/02/04 14:43:50 by adjoly ### ########.fr */
2023-11-10 18:49:34 +01:00
/* */
/* ************************************************************************** */
2024-02-04 15:11:02 +01:00
#include "../libft.h"
2023-11-10 18:49:34 +01:00
static int ft_countword(char const *s, char sep)
{
int i;
int w_count;
i = 0;
2023-11-11 01:28:12 +01:00
w_count = 0;
2023-11-10 18:49:34 +01:00
while (s[i])
{
2023-11-11 01:28:12 +01:00
if (s[i] != sep && (i == 0 || s[i - 1] == sep))
2023-11-10 18:49:34 +01:00
w_count++;
i++;
}
return (w_count);
}
2023-11-11 11:20:15 +01:00
static int ft_countletter(char const *s, char sep)
2023-11-11 01:28:12 +01:00
{
int i;
i = 0;
2023-11-11 11:20:15 +01:00
while (s[i] != sep && s[i] != '\0')
2023-11-11 01:28:12 +01:00
i++;
return (i);
}
2023-11-11 11:20:15 +01:00
static void *ft_freearr(char **arr)
{
int i;
i = 0;
while (arr[i])
{
free(arr[i]);
2023-11-13 17:04:34 +01:00
i++;
2023-11-11 11:20:15 +01:00
}
free(arr);
return (NULL);
}
2023-11-13 17:04:34 +01:00
char **ft_split_to_result(char **tab, char const *s, char c)
2023-11-10 18:49:34 +01:00
{
2023-11-11 11:20:15 +01:00
int i;
int j;
2023-11-13 17:04:34 +01:00
int k;
2023-11-10 18:49:34 +01:00
2023-11-13 17:04:34 +01:00
i = 0;
2023-11-11 11:20:15 +01:00
j = 0;
2023-11-13 17:04:34 +01:00
while (s[i])
2023-11-11 01:28:12 +01:00
{
2023-11-13 17:04:34 +01:00
if (s[i] != c)
2023-11-11 01:28:12 +01:00
{
2023-11-13 17:04:34 +01:00
k = 0;
tab[j] = ft_calloc(ft_countletter(&s[i], c) + 1, sizeof(char));
if (!tab[j])
return (ft_freearr(tab));
while (s[i] && s[i] != c)
tab[j][k++] = s [i++];
tab[j][k] = '\0';
j++;
2023-11-11 01:28:12 +01:00
}
2023-11-13 17:04:34 +01:00
else
i++;
2023-11-11 01:28:12 +01:00
}
2023-11-13 17:04:34 +01:00
tab[j] = NULL;
return (tab);
}
char **ft_split(char const *s, char c)
{
char **result;
if (s == NULL)
return (NULL);
result = ft_calloc(ft_countword(s, c) + 1, sizeof(char *));
if (!result)
return (NULL);
result = ft_split_to_result(result, s, c);
2023-11-10 18:49:34 +01:00
return (result);
}