Archived
1
0
This repository has been archived on 2024-10-25. You can view files and clone it, but cannot push or open issues or pull requests.
libft/ft_split.c

95 lines
2.0 KiB
C
Raw Normal View History

2023-11-10 18:49:34 +01:00
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* ft_split.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: adjoly <adjoly@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2023/11/09 19:04:42 by adjoly #+# #+# */
2023-11-11 11:20:15 +01:00
/* Updated: 2023/11/11 11:15:37 by adjoly ### ########.fr */
2023-11-10 18:49:34 +01:00
/* */
/* ************************************************************************** */
#include "libft.h"
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;
free(arr[i]);
while (arr[i])
{
i++;
free(arr[i]);
}
free(arr);
return (NULL);
}
2023-11-10 18:49:34 +01:00
char **ft_split(char const *s, char c)
{
int w_count;
char **result;
2023-11-11 11:20:15 +01:00
int i;
int j;
int k;
2023-11-10 18:49:34 +01:00
2023-11-11 11:20:15 +01:00
i = 0;
j = 0;
if (s == NULL)
return (NULL);
2023-11-10 18:49:34 +01:00
w_count = ft_countword(s, c);
2023-11-11 01:28:12 +01:00
result = malloc((w_count + 1) * sizeof(char *));
if (result == NULL)
2023-11-11 11:20:15 +01:00
return (ft_freearr(result));
while (i < w_count)
2023-11-11 01:28:12 +01:00
{
2023-11-11 11:20:15 +01:00
while (s[j] == c)
j++;
if (s[j] != '\0' && s[j] != c)
2023-11-11 01:28:12 +01:00
{
2023-11-11 11:20:15 +01:00
k = 0;
result[i] = malloc((ft_countletter(&s[j], c) + 1) * sizeof(char));
if (result == NULL)
return (ft_freearr(result));
while (s[j] != c)
{
result[i][k] = s[j];
j++;
k++;
}
result[i][k] = '\0';
2023-11-11 01:28:12 +01:00
}
2023-11-11 11:20:15 +01:00
i++;
2023-11-11 01:28:12 +01:00
}
2023-11-11 11:20:15 +01:00
result[i] = NULL;
2023-11-10 18:49:34 +01:00
return (result);
}