6 Commits

Author SHA1 Message Date
1235516c09 FIX: dumb error 2026-01-20 13:39:31 +01:00
e947183aab FIX: parsing cleanup 2026-01-17 16:36:59 +01:00
Maoake Teriierooiterai
52e1ef8947 rm test_push_swap.sh 2026-01-17 16:07:50 +01:00
Maoake Teriierooiterai
b2652cacc7 Merge branch 'master' of github.com:DavidGailleton/42-Push_Swap into fix_bench 2026-01-17 16:06:40 +01:00
Maoake Teriierooiterai
ae1a91c7c9 fixed bench 2026-01-17 16:06:12 +01:00
798886976c FIX; add error for invalid flag in bonus 2026-01-17 16:05:50 +01:00
8 changed files with 37 additions and 141 deletions

View File

@@ -58,16 +58,14 @@ static int tester(t_stacks *stacks)
while (buf) while (buf)
{ {
if (!apply_operation(stacks, buf)) if (!apply_operation(stacks, buf))
break ; {
secure_write(2, "Error\n", 6);
return (0);
}
free(buf); free(buf);
buf = get_next_line(0); buf = get_next_line(0);
} }
if (!is_stacks_b_empty(stacks)) if (!is_stacks_b_empty(stacks) || !check_order(stacks->a))
{
secure_write(1, "KO\n", 3);
return (0);
}
if (!check_order(stacks->a))
{ {
secure_write(1, "KO\n", 3); secure_write(1, "KO\n", 3);
return (0); return (0);

View File

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

View File

@@ -40,7 +40,7 @@ static void print_disorder(t_stacks *stacks)
static void print_algo(t_stacks *stacks) static void print_algo(t_stacks *stacks)
{ {
secure_write(2, "[bench] algo: ", 14); secure_write(2, "[bench] strategy: ", 18);
if (stacks->algo == 0) if (stacks->algo == 0)
{ {
secure_write(2, "Adaptive", 8); secure_write(2, "Adaptive", 8);

View File

@@ -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);
} else if (stacks->algo == 2)
else if (ft_strncmp(argv[pos], "--medium", 30) && pos > 0)
{
stacks->algo = 2;
medium(stacks); medium(stacks);
} else if (stacks->algo == 3)
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;
} }

View File

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

9
main.c
View File

@@ -27,13 +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);
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);

View File

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

View File

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