From 7af46f10e23296baa72b70e5fbc72eb35e2a9b01 Mon Sep 17 00:00:00 2001 From: Dominik Kaiser Date: Tue, 7 May 2024 15:18:01 +0200 Subject: Add changes from input_handling This is not how it should be done, but I just need to finish this quickly. --- src/input_handling.c | 56 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 56 insertions(+) create mode 100644 src/input_handling.c (limited to 'src/input_handling.c') diff --git a/src/input_handling.c b/src/input_handling.c new file mode 100644 index 0000000..e4bf7d6 --- /dev/null +++ b/src/input_handling.c @@ -0,0 +1,56 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* input_handling.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: dkaiser +#include +#include + +static char **get_cmds(int argc, char *argv[], char *envp[]) +{ + char **cmds; + int i; + char **path; + char *pwd; + + cmds = malloc(sizeof(char *) * (argc - 2)); + if (!cmds) + return (NULL); + path = get_split_path(envp); + // TODO: Free on fail + pwd = get_pwd(envp); + i = 2; + while (i < argc - 1) + { + cmds[i - 2] = get_cmd_path(argv[i], path, pwd); + i++; + } + i = 0; + while (path[i]) + free(path[i++]); + free(path); + return (cmds); +} + +t_pxdata *get_pxdata(int argc, char *argv[], char *envp[]) +{ + t_pxdata *result; + + result = malloc(sizeof(t_pxdata)); + if (!result) + return (NULL); // TODO: Check if an error message needs to be sent + result->in_fd = open(argv[1], O_RDONLY); + result->out_fd = open(argv[--argc], O_WRONLY | O_CREAT | O_TRUNC); + result->cmds = get_cmds(argc, argv, envp); + return (result); +} -- cgit v1.2.3