diff options
| author | Christopher Uhlig | 2024-10-25 20:44:14 +0200 |
|---|---|---|
| committer | Christopher Uhlig | 2024-10-25 20:44:14 +0200 |
| commit | eafa035f9a72961280f4b1bb8f405f40000d3212 (patch) | |
| tree | 3566b9bcfde24d59afc7591179647f393184cfaf /src/execute_cmd.c | |
| parent | ca4acea03cda19c2a0f0fd168d3c8fd418d71e04 (diff) | |
| parent | 15d8385f8ecf30e1ca74025b12fed7e45349b706 (diff) | |
| download | minishell-eafa035f9a72961280f4b1bb8f405f40000d3212.tar.gz minishell-eafa035f9a72961280f4b1bb8f405f40000d3212.zip | |
resolved merge conflicts
Diffstat (limited to 'src/execute_cmd.c')
| -rw-r--r-- | src/execute_cmd.c | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/src/execute_cmd.c b/src/execute_cmd.c new file mode 100644 index 0000000..fa7677f --- /dev/null +++ b/src/execute_cmd.c @@ -0,0 +1,59 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* execute_cmd.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: dkaiser <dkaiser@student.42heilbronn.de +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2024/10/21 13:58:56 by dkaiser #+# #+# */ +/* Updated: 2024/10/25 13:31:16 by dkaiser ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "minishell.h" +#include <stdlib.h> +#include <sys/_types/_pid_t.h> +#include <sys/_types/_s_ifmt.h> +#include <sys/fcntl.h> +#include <unistd.h> +#include <fcntl.h> + +int execute_cmd(t_cmd *cmd, t_env *env) +{ + int result; + char *cmd_path; + int fd; + + cmd_path = get_cmd_path(cmd->args[0], env); + cmd->args[0] = cmd_path; + + if (cmd->redirs[0].type == INPUT_FILE) + { + fd = open(cmd->redirs[0].specifier, O_RDONLY); + if (fd < 0) + return (EXIT_FAILURE); + dup2(fd, STDIN_FILENO); + } + else if (cmd->redirs[0].type == INPUT_LIMITER) + { + dbg("INPUT_LIMITER"); + } + if (cmd->redirs[1].type == OUTPUT_APPEND) + { + dbg("OUTPUT_APPEND"); + fd = open(cmd->redirs[1].specifier, O_WRONLY | O_CREAT | O_APPEND); + if (fd < 0) + return (EXIT_FAILURE); + dup2(fd, STDOUT_FILENO); + } + else if (cmd->redirs[1].type == OUTPUT_OVERRIDE) + { + fd = open(cmd->redirs[1].specifier, O_WRONLY | O_CREAT | O_TRUNC); + if (fd < 0) + return (EXIT_FAILURE); + dup2(fd, STDOUT_FILENO); + dbg("OUTPUT_OVERRIDE"); + } + result = execve(cmd->args[0], cmd->args, env_to_strlst(env)); + return (result); +} |
