summaryrefslogtreecommitdiff
path: root/main.c
diff options
context:
space:
mode:
authorDominik Kaiser2024-04-17 10:00:27 +0200
committerGitHub2024-04-17 10:00:27 +0200
commit09176f10ff4fbde374825a064241cdc3ff163623 (patch)
tree1202c4465fc1ce80cc74bbca9a7fbcb9a4ccad25 /main.c
parentc16af7775f6d4bb56bb8a0891ec646032f442993 (diff)
parentca607daf01f965a0a07263f57cdc1274e3a24fe8 (diff)
downloadpush_swap-09176f10ff4fbde374825a064241cdc3ff163623.tar.gz
push_swap-09176f10ff4fbde374825a064241cdc3ff163623.zip
Merge branch 'master' into add_2op_optimization
Diffstat (limited to 'main.c')
-rw-r--r--main.c79
1 files changed, 48 insertions, 31 deletions
diff --git a/main.c b/main.c
index ed2a579..3881df0 100644
--- a/main.c
+++ b/main.c
@@ -6,51 +6,69 @@
/* By: dkaiser <dkaiser@student.42heilbronn.de +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2024/04/12 17:03:30 by dkaiser #+# #+# */
-<<<<<<< Updated upstream
-/* Updated: 2024/04/15 17:53:19 by dkaiser ### ########.fr */
-=======
/* Updated: 2024/04/17 09:42:43 by dkaiser ### ########.fr */
->>>>>>> Stashed changes
/* */
/* ************************************************************************** */
#include "libft/ft_printf.h"
#include "push_swap.h"
-int main(int argc, char *argv[])
+static void free_data(t_psdata *data)
{
- t_stack *stack_a;
- t_stack *stack_b;
- t_list *pscmds;
-
- stack_a = create_stack(argc, argv);
- if (!stack_a)
+ if (data)
{
- ft_putendl_fd("Error", 2);
- return (1);
+ if (data->a)
+ {
+ if (data->a->stack)
+ free(data->a->stack);
+ free(data->a);
+ }
+ if (data->b)
+ {
+ if (data->b->stack)
+ free(data->b->stack);
+ free(data->b);
+ }
+ free(data);
}
-<<<<<<< Updated upstream
+}
+
+static t_psdata *initialize_data(int argc, char *argv[])
+{
+ t_psdata *result;
- stack_b = malloc(sizeof(t_stack));
- if (!stack_b)
+ result = malloc(sizeof(t_psdata));
+ if (result)
{
- //free everything
+ result->a = create_stack(argc, argv);
+ if (result->a)
+ {
+ result->b = malloc(sizeof(t_stack));
+ if (result->b)
+ {
+ result->b->stack = malloc(sizeof(int) * (argc - 1));
+ if (result->b->stack)
+ {
+ result->b->size = 0;
+ return result;
+ }
+ }
+ }
}
- stack_b->stack = malloc(sizeof(int) * (argc - 1));
- if (!stack_b->stack)
+ free_data(result);
+ return NULL;
+}
+
+int main(int argc, char *argv[])
+{
+ t_psdata *data;
+
+ data = initialize_data(argc, argv);
+ if (!data)
{
- //free everything
+ ft_putendl_fd("Error", 2);
+ return (1);
}
- stack_b->size = 0;
- stack_optimize(stack_a);
- pscmds = stack_sort(stack_a, stack_b);
- /* optimize_commands(&pscmds); */
- print_commands(pscmds);
- ft_printf("\nA: ");
- stack_print(stack_a);
- ft_printf("B: ");
- stack_print(stack_b);
-=======
stack_optimize(data->a);
stack_sort(data);
optimize_commands(data);
@@ -59,6 +77,5 @@ int main(int argc, char *argv[])
/* stack_print(data->a); */
/* ft_printf("B: "); */
/* stack_print(data->b); */
->>>>>>> Stashed changes
return (0);
}