mirror of
https://github.com/DavidGailleton/42-Push_Swap.git
synced 2026-01-27 08:41:58 +00:00
FIX: parsing cleanup
This commit is contained in:
@@ -46,14 +46,10 @@ void complex(t_stacks *stacks)
|
|||||||
radix(stacks);
|
radix(stacks);
|
||||||
}
|
}
|
||||||
|
|
||||||
void adaptive(t_stacks *stacks, char **tab)
|
void adaptive(t_stacks *stacks)
|
||||||
{
|
{
|
||||||
int i;
|
|
||||||
float disorder;
|
float disorder;
|
||||||
|
|
||||||
i = 0;
|
|
||||||
while (!ft_isdigit(tab[i][0]) && tab[i])
|
|
||||||
i++;
|
|
||||||
disorder = stacks->disorder;
|
disorder = stacks->disorder;
|
||||||
if (disorder < 0.2)
|
if (disorder < 0.2)
|
||||||
simple(stacks);
|
simple(stacks);
|
||||||
@@ -61,5 +57,4 @@ void adaptive(t_stacks *stacks, char **tab)
|
|||||||
medium(stacks);
|
medium(stacks);
|
||||||
else
|
else
|
||||||
complex(stacks);
|
complex(stacks);
|
||||||
return ;
|
|
||||||
}
|
}
|
||||||
|
|||||||
57
flags/flag.c
57
flags/flag.c
@@ -26,61 +26,14 @@ int calcul_mod(int argc, char **argv)
|
|||||||
return (mod);
|
return (mod);
|
||||||
}
|
}
|
||||||
|
|
||||||
int pos_flag(char **argv, int mod)
|
void flags(t_stacks *stacks)
|
||||||
{
|
{
|
||||||
if (mod == 1 || mod == 4)
|
if (stacks->algo == 1)
|
||||||
{
|
|
||||||
if (!ft_strncmp(argv[1], "--bench", 20))
|
|
||||||
return (1);
|
|
||||||
}
|
|
||||||
else if (mod == 2 || mod == 5)
|
|
||||||
{
|
|
||||||
if (!ft_strncmp(argv[1], "--bench", 20))
|
|
||||||
return (1);
|
|
||||||
else
|
|
||||||
return (2);
|
|
||||||
}
|
|
||||||
return (0);
|
|
||||||
}
|
|
||||||
|
|
||||||
int pos_bench(char **argv, int mod)
|
|
||||||
{
|
|
||||||
if (mod == 1 || mod == 4)
|
|
||||||
{
|
|
||||||
if (ft_strncmp(argv[1], "--bench", 20))
|
|
||||||
return (1);
|
|
||||||
}
|
|
||||||
else if (mod == 2 || mod == 5)
|
|
||||||
{
|
|
||||||
if (ft_strncmp(argv[1], "--bench", 20))
|
|
||||||
return (1);
|
|
||||||
else
|
|
||||||
return (2);
|
|
||||||
}
|
|
||||||
return (0);
|
|
||||||
}
|
|
||||||
|
|
||||||
void flags(int pos, int pos_b, char **argv, t_stacks *stacks)
|
|
||||||
{
|
|
||||||
if (ft_strncmp(argv[pos], "--simple", 30) && pos > 0)
|
|
||||||
{
|
|
||||||
stacks->algo = 1;
|
|
||||||
simple(stacks);
|
simple(stacks);
|
||||||
}
|
if (stacks->algo == 1)
|
||||||
else if (ft_strncmp(argv[pos], "--medium", 30) && pos > 0)
|
|
||||||
{
|
|
||||||
stacks->algo = 2;
|
|
||||||
medium(stacks);
|
medium(stacks);
|
||||||
}
|
if (stacks->algo == 1)
|
||||||
else if (ft_strncmp(argv[pos], "--complex", 30) && pos > 0)
|
|
||||||
{
|
|
||||||
stacks->algo = 3;
|
|
||||||
complex(stacks);
|
complex(stacks);
|
||||||
}
|
|
||||||
else if (ft_strncmp(argv[pos], "--adaptive", 30) && pos > 0)
|
|
||||||
adaptive(stacks, argv);
|
|
||||||
else
|
else
|
||||||
adaptive(stacks, argv);
|
adaptive(stacks);
|
||||||
if (pos_b > 0)
|
|
||||||
stacks->bench = 1;
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -16,10 +16,8 @@
|
|||||||
void simple(t_stacks *stacks);
|
void simple(t_stacks *stacks);
|
||||||
void medium(t_stacks *stacks);
|
void medium(t_stacks *stacks);
|
||||||
void complex(t_stacks *stacks);
|
void complex(t_stacks *stacks);
|
||||||
void adaptive(t_stacks *stacks, char **tab);
|
void adaptive(t_stacks *stacks);
|
||||||
void flags(int pos, int pos_b, char **argv, t_stacks *stacks);
|
void flags(t_stacks *stacks);
|
||||||
int pos_bench(char **argv, int mod);
|
|
||||||
int pos_flag(char **argv, int mod);
|
|
||||||
int calcul_mod(int argc, char **argv);
|
int calcul_mod(int argc, char **argv);
|
||||||
void print_bench(t_stacks *stacks);
|
void print_bench(t_stacks *stacks);
|
||||||
|
|
||||||
|
|||||||
12
main.c
12
main.c
@@ -27,16 +27,8 @@ static int push_swap(char **tab, int len, int mod)
|
|||||||
if (!stacks)
|
if (!stacks)
|
||||||
return (0);
|
return (0);
|
||||||
indexer(stacks);
|
indexer(stacks);
|
||||||
if (check_order(stacks->a))
|
if (!check_order(stacks->a))
|
||||||
{
|
flags(stacks);
|
||||||
flags(0, pos_bench(tab, mod), tab, stacks);
|
|
||||||
if (stacks->bench == 1)
|
|
||||||
print_bench(stacks);
|
|
||||||
free_all(stacks);
|
|
||||||
return (0);
|
|
||||||
}
|
|
||||||
stacks->disorder = compute_disorder(tab, wich_mod(mod));
|
|
||||||
flags(pos_flag(tab, mod), pos_bench(tab, mod), tab, stacks);
|
|
||||||
if (stacks->bench == 1)
|
if (stacks->bench == 1)
|
||||||
print_bench(stacks);
|
print_bench(stacks);
|
||||||
free_all(stacks);
|
free_all(stacks);
|
||||||
|
|||||||
@@ -1,64 +0,0 @@
|
|||||||
/* ************************************************************************** */
|
|
||||||
/* */
|
|
||||||
/* ::: :::::::: */
|
|
||||||
/* checker.c :+: :+: :+: */
|
|
||||||
/* +:+ +:+ +:+ */
|
|
||||||
/* By: dgaillet <dgaillet@student.42.fr> +#+ +:+ +#+ */
|
|
||||||
/* +#+#+#+#+#+ +#+ */
|
|
||||||
/* Created: 2026/01/08 12:37:12 by dgaillet #+# #+# */
|
|
||||||
/* Updated: 2026/01/08 13:17:36 by dgaillet ### ########lyon.fr */
|
|
||||||
/* */
|
|
||||||
/* ************************************************************************** */
|
|
||||||
|
|
||||||
#include "push_swap.h"
|
|
||||||
#include "parsing.h"
|
|
||||||
|
|
||||||
static int check_digits(char *str)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
|
|
||||||
i = 0;
|
|
||||||
while (str[i])
|
|
||||||
{
|
|
||||||
if (!ft_isdigit(str[i]) && str[i] != ' ')
|
|
||||||
return (0);
|
|
||||||
i++;
|
|
||||||
}
|
|
||||||
return (1);
|
|
||||||
}
|
|
||||||
|
|
||||||
static int check_flags(char *str)
|
|
||||||
{
|
|
||||||
if (!ft_strncmp("--simple", str, ft_strlen(str)))
|
|
||||||
return (1);
|
|
||||||
else if (!ft_strncmp("--medium", str, ft_strlen(str)))
|
|
||||||
return (1);
|
|
||||||
else if (!ft_strncmp("--complex", str, ft_strlen(str)))
|
|
||||||
return (1);
|
|
||||||
else if (!ft_strncmp("--adaptative", str, ft_strlen(str)))
|
|
||||||
return (1);
|
|
||||||
return (0);
|
|
||||||
}
|
|
||||||
|
|
||||||
int checker(int argc, char **argv)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
int methods_flag;
|
|
||||||
int bench;
|
|
||||||
|
|
||||||
bench = 0;
|
|
||||||
methods_flag = 0;
|
|
||||||
i = 0;
|
|
||||||
while (++i < argc)
|
|
||||||
{
|
|
||||||
if (check_flags(argv[1]) && !methods_flag)
|
|
||||||
methods_flag = 1;
|
|
||||||
else if (!ft_strncmp("--bench", argv[1], ft_strlen(argv[1])) && !bench)
|
|
||||||
bench = 1;
|
|
||||||
else if (check_digits(argv[1]))
|
|
||||||
continue ;
|
|
||||||
else
|
|
||||||
return (0);
|
|
||||||
}
|
|
||||||
return (1);
|
|
||||||
}
|
|
||||||
@@ -65,6 +65,25 @@ static void set_t_stacks(t_stacks *stacks)
|
|||||||
stacks->rrr = 0;
|
stacks->rrr = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void set_flags(int argc, char **argv, t_stacks *stacks)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
i = 1;
|
||||||
|
while (i < argc)
|
||||||
|
{
|
||||||
|
if (ft_strncmp(argv[i], "--simple", ft_strlen(argv[i])))
|
||||||
|
stacks->algo = 1;
|
||||||
|
else if (ft_strncmp(argv[i], "--medium", ft_strlen(argv[i])))
|
||||||
|
stacks->algo = 2;
|
||||||
|
else if (ft_strncmp(argv[i], "--complex", ft_strlen(argv[i])))
|
||||||
|
stacks->algo = 3;
|
||||||
|
if (ft_strncmp(argv[i], "--bench", ft_strlen(argv[i])))
|
||||||
|
stacks->bench = 1;
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
t_stacks *init_stacks(int argc, char **argv, int mod)
|
t_stacks *init_stacks(int argc, char **argv, int mod)
|
||||||
{
|
{
|
||||||
t_stacks *stacks;
|
t_stacks *stacks;
|
||||||
@@ -81,5 +100,7 @@ t_stacks *init_stacks(int argc, char **argv, int mod)
|
|||||||
return (NULL);
|
return (NULL);
|
||||||
}
|
}
|
||||||
stacks->a = a;
|
stacks->a = a;
|
||||||
|
set_flags(argc, argv, stacks);
|
||||||
|
stacks->disorder = compute_disorder(argv, wich_mod(mod));
|
||||||
return (stacks);
|
return (stacks);
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user