sync
This commit is contained in:
@@ -6,13 +6,15 @@
|
||||
/* By: gbaconni <gbaconni@42lausanne.ch> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2021/08/22 18:14:04 by gbaconni #+# #+# */
|
||||
/* Updated: 2021/08/24 13:00:34 by gbaconni ### ########.fr */
|
||||
/* Updated: 2021/08/25 18:26:47 by gbaconni ### ########.fr */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <stdio.h>
|
||||
|
||||
int g_t = 0;
|
||||
|
||||
static char *ft_strncpy(char *dest, char *src, unsigned int n)
|
||||
{
|
||||
unsigned int i;
|
||||
@@ -34,7 +36,7 @@ static char *ft_strncpy(char *dest, char *src, unsigned int n)
|
||||
|
||||
static int ft_is_charset(char c, char *charset)
|
||||
{
|
||||
int i;
|
||||
int i;
|
||||
|
||||
i = 0;
|
||||
while (charset[i] != '\0')
|
||||
@@ -52,6 +54,8 @@ static int ft_split_len(char *str, char *charset)
|
||||
int size;
|
||||
|
||||
size = 2;
|
||||
if (str == NULL || charset == NULL)
|
||||
return (size);
|
||||
p_str = str;
|
||||
while (*p_str != '\0')
|
||||
{
|
||||
@@ -77,24 +81,25 @@ char **ft_split(char *str, char *charset)
|
||||
{
|
||||
char **strs;
|
||||
char *start;
|
||||
int size;
|
||||
int i;
|
||||
|
||||
size = ft_split_len(str, charset);
|
||||
strs = malloc((size) * sizeof(strs));
|
||||
strs = malloc(ft_split_len(str, charset) * sizeof(strs));
|
||||
if (strs == NULL || charset == NULL || str == NULL)
|
||||
return (NULL);
|
||||
start = str;
|
||||
i = 0;
|
||||
while (1)
|
||||
{
|
||||
if (ft_is_charset(*str, charset) == 1 || *str == '\0')
|
||||
if (ft_is_charset(*str, charset) == 1 || (*str == '\0' && g_t > 0))
|
||||
{
|
||||
size = str - start;
|
||||
if (size > 0)
|
||||
strs[i++] = ft_copy(start, size);
|
||||
if (str - start > 0)
|
||||
strs[i++] = ft_copy(start, str - start);
|
||||
start = str + 1;
|
||||
if (*str == '\0')
|
||||
break ;
|
||||
}
|
||||
else
|
||||
g_t++;
|
||||
if (*str == '\0')
|
||||
break ;
|
||||
str++;
|
||||
}
|
||||
strs[i] = ft_copy(str, 0);
|
||||
|
||||
@@ -6,7 +6,7 @@
|
||||
/* By: gbaconni <gbaconni@42lausanne.ch> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2021/08/18 10:50:59 by gbaconni #+# #+# */
|
||||
/* Updated: 2021/08/24 11:56:21 by gbaconni ### ########.fr */
|
||||
/* Updated: 2021/08/25 14:11:02 by gbaconni ### ########.fr */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
@@ -31,6 +31,8 @@ int main(int argc, char *argv[])
|
||||
}
|
||||
str = argv[1];
|
||||
charset = argv[2];
|
||||
if (str[0] == '\0')
|
||||
str = NULL;
|
||||
strs = ft_split(str, charset);
|
||||
printf("str=%s charset=%s (ft_split)\n", str, charset);
|
||||
i = 0;
|
||||
|
||||
@@ -3,7 +3,7 @@ set -e
|
||||
rm -f a.out
|
||||
#norminette -R CheckForbiddenSourceHeader ft_*.c
|
||||
norminette -R CheckForbiddenSourceHeader
|
||||
gcc -Wall -Wextra -Werror -o a.out *.c
|
||||
gcc -Wall -Wextra -Werror -fsanitize=address -g -o a.out *.c
|
||||
echo $(basename $PWD):
|
||||
./a.out "$@"
|
||||
rm -f a.out
|
||||
|
||||
Reference in New Issue
Block a user