diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/e_builtins.c | 4 | ||||
-rw-r--r-- | src/e_externs.c | 3 | ||||
-rw-r--r-- | src/e_externs_pipes.c | 4 | ||||
-rw-r--r-- | src/e_redirs.c | 85 | ||||
-rw-r--r-- | src/e_redirs.h (renamed from src/m_redirs.h) | 4 | ||||
-rw-r--r-- | src/m_redirs.c | 61 | ||||
-rw-r--r-- | src/p_redirs.c | 18 | ||||
-rw-r--r-- | src/s_com.c | 2 |
8 files changed, 107 insertions, 74 deletions
diff --git a/src/e_builtins.c b/src/e_builtins.c index 92af2c3..90f3775 100644 --- a/src/e_builtins.c +++ b/src/e_builtins.c @@ -19,8 +19,8 @@ #include "b_builtins.h" #include "b_export_next.h" #include "b_export_mute.h" +#include "e_redirs.h" #include "m_loop.h" -#include "m_redirs.h" #include "s_com.h" #include "s_destroy.h" #include "s_line.h" @@ -50,7 +50,7 @@ static void if (ptr->env_fork != NULL) e_export_env_fork(ptr, msh); - dup_redirs(ptr, msh); + e_dup_redirs(ptr, msh); ret = 0; if (bu_id == FT_ID_H && msh->fd == STDIN_FILENO) ret = msh->bu_ptr[bu_id](ptr->argv + 1, msh); diff --git a/src/e_externs.c b/src/e_externs.c index 8761986..f4b608c 100644 --- a/src/e_externs.c +++ b/src/e_externs.c @@ -22,7 +22,7 @@ #include "b_export_next.h" #include "d_define.h" #include "f_fail.h" -#include "m_redirs.h" +#include "e_redirs.h" #include "s_com.h" #include "s_destroy.h" #include "s_line.h" @@ -72,6 +72,7 @@ static void { if (ptr->env_fork != NULL) e_export_env_fork(ptr, msh); + e_dup_redirs(ptr, msh); e_extern_child(fullpath, ptr, msh); } else if (pid < 0) diff --git a/src/e_externs_pipes.c b/src/e_externs_pipes.c index ca843d0..64581e4 100644 --- a/src/e_externs_pipes.c +++ b/src/e_externs_pipes.c @@ -21,7 +21,7 @@ #include "d_define.h" #include "f_fail.h" -#include "m_redirs.h" +#include "e_redirs.h" #include "s_destroy.h" #include "s_line.h" #include "s_lpipes.h" @@ -38,7 +38,7 @@ static void uint8_t bu_id; uint8_t ret; - dup_redirs(ptr, msh); + e_dup_redirs(ptr, msh); if (ft_strncmp(fullpath[pipe_id], "builtin", 8) == 0) { bu_id = u_get_builtin_id(ptr->bin); diff --git a/src/e_redirs.c b/src/e_redirs.c new file mode 100644 index 0000000..474e043 --- /dev/null +++ b/src/e_redirs.c @@ -0,0 +1,85 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* e_redirs.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rbousset <marvin@42.fr> +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/02/14 17:19:27 by rbousset #+# #+# */ +/* Updated: 2020/02/14 17:19:29 by rbousset ### ########lyon.fr */ +/* */ +/* ************************************************************************** */ + +#include <libft.h> +#include <stdint.h> +#include <stddef.h> +#include <fcntl.h> +#include <unistd.h> + +#include "f_fail.h" +#include "s_destroy.h" +#include "s_line.h" +#include "s_struct.h" + +static void e_redir_minus_one(struct s_lredir *ptr, t_msh *msh) +{ + int32_t fd; + + if ((fd = open(ptr->path, O_RDONLY)) == -1) + { + f_redir(ptr->path, msh); + return ; + } + dup2(fd, STDIN_FILENO); + close(fd); +} + +static void e_redir_plus_one(struct s_lredir *ptr, t_msh *msh) +{ + int32_t fd; + + if ((fd = open(ptr->path, O_CREAT | O_TRUNC | O_WRONLY, 0644)) == -1) + { + f_redir(ptr->path, msh); + return ; + } + dup2(fd, ptr->fd); + close(fd); +} + +static void e_redir_plus_two(struct s_lredir *ptr, t_msh *msh) +{ + int32_t fd; + + if ((fd = open(ptr->path, O_CREAT | O_APPEND | O_WRONLY, 0644)) == -1) + { + f_redir(ptr->path, msh); + return ; + } + dup2(fd, ptr->fd); + close(fd); +} + +void e_dup_redirs(const t_com *com, t_msh *msh) +{ + struct s_lredir *ptr; + + ptr = com->rdr; + while (ptr != NULL) + { + ft_printf("PATH: [%s]; FD: [%d]; RDR: [%hhd]\n", ptr->path, ptr->fd, ptr->redir); + if (ptr->redir == -1) + { + e_redir_minus_one(ptr, msh); + } + else if (ptr->redir == 1) + { + e_redir_plus_one(ptr, msh); + } + else if (ptr->redir == 2) + { + e_redir_plus_two(ptr, msh); + } + ptr = ptr->next; + } +} diff --git a/src/m_redirs.h b/src/e_redirs.h index fc33758..7fddea0 100644 --- a/src/m_redirs.h +++ b/src/e_redirs.h @@ -1,7 +1,7 @@ /* ************************************************************************** */ /* */ /* ::: :::::::: */ -/* m_redirs.h :+: :+: :+: */ +/* e_redirs.h :+: :+: :+: */ /* +:+ +:+ +:+ */ /* By: rbousset <marvin@42.fr> +#+ +:+ +#+ */ /* +#+#+#+#+#+ +#+ */ @@ -15,6 +15,6 @@ #include "s_struct.h" -void dup_redirs(const t_com *ptr, t_msh *msh); +void e_dup_redirs(const t_com *com, t_msh *msh); #endif diff --git a/src/m_redirs.c b/src/m_redirs.c deleted file mode 100644 index 40a6646..0000000 --- a/src/m_redirs.c +++ /dev/null @@ -1,61 +0,0 @@ -/* ************************************************************************** */ -/* */ -/* ::: :::::::: */ -/* m_redirs.c :+: :+: :+: */ -/* +:+ +:+ +:+ */ -/* By: rbousset <marvin@42.fr> +#+ +:+ +#+ */ -/* +#+#+#+#+#+ +#+ */ -/* Created: 2020/02/14 17:19:27 by rbousset #+# #+# */ -/* Updated: 2020/02/14 17:19:29 by rbousset ### ########lyon.fr */ -/* */ -/* ************************************************************************** */ - -#include <libft.h> -#include <fcntl.h> -#include <unistd.h> -#include <errno.h> - -#include "f_fail.h" -#include "s_destroy.h" -#include "s_line.h" -#include "s_struct.h" - -void dup_redirs(const t_com *ptr, t_msh *msh) -{ - (void)ptr; - (void)msh; - /* int32_t fd; */ - - /* if (ptr->redir == -1) */ - /* { */ - /* if ((fd = open(ptr->rdrpath, O_RDONLY)) == -1) */ - /* { */ - /* f_redir(ptr->rdrpath, msh); */ - /* return ; */ - /* } */ - /* dup2(fd, STDIN_FILENO); */ - /* close(fd); */ - /* } */ - /* else if (ptr->redir == 1) */ - /* { */ - /* if ((fd = open(ptr->rdrpath, */ - /* O_CREAT | O_TRUNC | O_WRONLY, 0644)) == -1) */ - /* { */ - /* f_redir(ptr->rdrpath, msh); */ - /* return ; */ - /* } */ - /* dup2(fd, ptr->rdrfd); */ - /* close(fd); */ - /* } */ - /* else if (ptr->redir == 2) */ - /* { */ - /* if ((fd = open(ptr->rdrpath, */ - /* O_CREAT | O_APPEND | O_WRONLY, 0644)) == -1) */ - /* { */ - /* f_redir(ptr->rdrpath, msh); */ - /* return ; */ - /* } */ - /* dup2(fd, ptr->rdrfd); */ - /* close(fd); */ - /* } */ -} diff --git a/src/p_redirs.c b/src/p_redirs.c index 3f9e866..cf4cf1d 100644 --- a/src/p_redirs.c +++ b/src/p_redirs.c @@ -13,11 +13,13 @@ #include <libft.h> #include <stdint.h> #include <stddef.h> +#include <unistd.h> #include <limits.h> #include "d_define.h" #include "s_lredir.h" #include "s_struct.h" +#include "s_lredir.h" #include "u_utils.h" #include "u_parse.h" @@ -26,7 +28,15 @@ static void p_append_redir(const char path[], int8_t redir, t_com *com) { - struct s_lredir *rdr; + struct s_lredir *new; + + new = s_lredir_new(path, fd, redir); + if (new == NULL) + { + return ; + } + s_lredir_add_back(&com->rdr, new); + } static size_t p_get_path(char path[], @@ -88,12 +98,12 @@ static int8_t p_get_redir(char word[], char *ptr, t_com *com) pos[0] = 0; pos[1] = 0; - if ((fd = p_get_fd(word, ptr)) < 0) - fd = 0; + if ((fd = p_get_fd(word, ptr)) <= 0) + fd = STDOUT_FILENO; redir = (*ptr == '>') ? (1) : (-1); redir = (redir == 1 && *(ptr + 1) == '>') ? (2) : (redir); redir = (redir == -1 && *(ptr + 1) == '<') ? (-2) : (redir); - if (fd == 0) + if (fd == STDOUT_FILENO) pos[0] = (ptr - word); else pos[0] = (ptr - word) - ft_intlen(fd); diff --git a/src/s_com.c b/src/s_com.c index 45a6304..527829d 100644 --- a/src/s_com.c +++ b/src/s_com.c @@ -109,10 +109,8 @@ t_com com->rdr = NULL; nword[0] = C_NUL; ft_strlcpy(nword, word, ARG_MAX); - ft_printf("BEFORE: [%s]\n", nword); if (p_redirs(nword, &com) != 0) return (NULL); - ft_printf("AFTER: [%s]\n", nword); if (msh->alias != NULL) { ret = p_subst_alias(nword, TRUE, msh); |