aboutsummaryrefslogtreecommitdiff
path: root/ft_strsplit.c
diff options
context:
space:
mode:
authorCabergs Charles <cacharle@w-r4-p5.s19.be>2019-10-07 16:33:51 +0200
committerCabergs Charles <cacharle@w-r4-p5.s19.be>2019-10-07 16:33:51 +0200
commit8adeef1b50a3a819cf6525af94f1fbce62465a7e (patch)
tree2076ffde529f8f5350515105645353f76ee1f5e9 /ft_strsplit.c
parentea6d7d262950a918f1888d7b8d9f6bceb1aaf12e (diff)
downloadlibft-8adeef1b50a3a819cf6525af94f1fbce62465a7e.tar.gz
libft-8adeef1b50a3a819cf6525af94f1fbce62465a7e.tar.bz2
libft-8adeef1b50a3a819cf6525af94f1fbce62465a7e.zip
Added calloc and strlcpy, rename out of date
Diffstat (limited to 'ft_strsplit.c')
-rw-r--r--ft_strsplit.c77
1 files changed, 0 insertions, 77 deletions
diff --git a/ft_strsplit.c b/ft_strsplit.c
deleted file mode 100644
index 3b80bfb..0000000
--- a/ft_strsplit.c
+++ /dev/null
@@ -1,77 +0,0 @@
-/* ************************************************************************** */
-/* */
-/* ::: :::::::: */
-/* ft_strsplit.c :+: :+: :+: */
-/* +:+ +:+ +:+ */
-/* By: cacharle <marvin@42.fr> +#+ +:+ +#+ */
-/* +#+#+#+#+#+ +#+ */
-/* Created: 2019/10/07 10:22:09 by cacharle #+# #+# */
-/* Updated: 2019/10/07 11:11:15 by cacharle ### ########.fr */
-/* */
-/* ************************************************************************** */
-
-#include <stdlib.h>
-
-static size_t count_segment(char const *s, char c)
-{
- size_t counter;
-
- counter = 0;
- while (*s)
- {
- if (*s == c)
- {
- s++;
- continue ;
- }
- counter++;
- while (*s && *s != c)
- s++;
- }
- return (counter);
-}
-
-static char *ft_strndup(const char *s1, size_t n)
-{
- char *clone;
- size_t i;
-
- if ((clone = (char*)malloc(sizeof(char) * (n + 1))) == NULL)
- return (NULL);
- i = 0;
- while (i < n)
- {
- clone[i] = s1[i];
- i++;
- }
- clone[i] = '\0';
- return (clone);
-}
-
-char **ft_strsplit(char const *s, char c)
-{
- char **strs;
- size_t size;
- size_t i;
- size_t j;
-
- size = count_segment(s, c);
- if ((strs = (char**)malloc(sizeof(char*) * (size + 1))) == NULL)
- return (NULL);
- j = 0;
- while (*s)
- {
- if (*s == c)
- {
- s++;
- continue ;
- }
- i = 0;
- while (s[i] && s[i] != c)
- i++;
- strs[j++] = ft_strndup(s, i);
- s += i;
- }
- strs[j] = 0;
- return (strs);
-}