0
0
This commit is contained in:
Guy Baconniere
2021-08-25 18:29:24 +02:00
parent dac092452e
commit aaa10155a5
6 changed files with 42 additions and 95 deletions

View File

@@ -1,20 +1,9 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* ft_stock_str.h :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: gbaconni <gbaconni@42lausanne.ch> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/08/25 10:17:09 by gbaconni #+# #+# */
/* Updated: 2021/08/25 12:05:50 by gbaconni ### ########.fr */
/* */
/* ************************************************************************** */
#ifndef FT_STOCK_STR_H
# define FT_STOCK_STR_H
typedef struct s_stock_str
#ifndef FT_STOCK__STR_H
# define FT_STOCK__STR_H
typedef struct s_stock_str
{
int size;
char *str;
char *copy;
} t_stock_str;
int size;
char *str;
char *copy;
} t_stock_str;
#endif

View File

@@ -1,64 +1,22 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* s_stock_str.c :+: :+: :+: */
/* ft_point.h :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: gbaconni <gbaconni@42lausanne.ch> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2021/08/25 10:17:09 by gbaconni #+# #+# */
/* Updated: 2021/08/25 12:05:50 by gbaconni ### ########.fr */
/* Created: 2021/08/20 10:17:09 by gbaconni #+# #+# */
/* Updated: 2021/08/20 12:05:50 by gbaconni ### ########.fr */
/* */
/* ************************************************************************** */
#include <stdlib.h>
#include "ft_stock_str.h"
#ifndef FT_POINT_H
# define FT_POINT_H
int ft_strlen(char *str)
typedef struct s_point
{
int i;
i = 0;
while (str[i] != '\0')
i++;
return (i);
}
char *ft_strcopy(char *str)
{
char *result;
int i;
int len;
len = ft_strlen(str);
result = (char *) malloc((len + 1) * sizeof(char));
i = 0;
while (str[i] != '\0')
{
result[i] = str[i];
i++;
}
result[i] = '\0';
return (result);
}
struct s_stock_str *ft_strs_to_tab(int ac, char **av)
{
int i;
t_stock_str *result;
result = (t_stock_str *) malloc((ac + 1) * sizeof(result));
if (result == NULL)
return (NULL);
i = 0;
while (i < ac)
{
result[i].size = ft_strlen(av[i]);
result[i].str = av[i];
result[i].copy = ft_strcopy(av[i]);
i++;
}
result[i].size = 0;
result[i].str = 0;
result[i].copy = 0;
return ((struct s_stock_str*) result);
}
int x;
int y;
} t_point;
void set_point(t_point *point);
#endif

View File

@@ -10,23 +10,16 @@
/* */
/* ************************************************************************** */
#include <stdio.h>
#include "ft_stock_str.h"
struct s_stock_str *ft_strs_to_tab(int ac, char **av);
int main(int argc, char **argv)
int main(void)
{
t_stock_str *result;
int i;
char **av;
int ac;
(void) result;
result = ft_strs_to_tab(argc, argv);
i = 0;
while (result[i].size > 0)
{
printf("result[%d] = { size=%d, str=%s, copy=%s\n}", i, result[i].size, result[i].str, result[i].copy);
i++;
}
result = ft_strs_to_tab(ac, av)
return (0);
}

View File

@@ -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);

View File

@@ -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;

View File

@@ -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