From 767b1cceaf1487dde84dcff3c0b58cadbce61d21 Mon Sep 17 00:00:00 2001 From: JozanLeClerc Date: Sat, 19 Sep 2020 17:14:56 +0200 Subject: Good luck have fuck --- src/m_redirs.c | 23 ++++++++++++++++------- src/p_lblock.c | 5 +---- src/s_struct.h | 2 +- 3 files changed, 18 insertions(+), 12 deletions(-) diff --git a/src/m_redirs.c b/src/m_redirs.c index 91014bb..50e416a 100644 --- a/src/m_redirs.c +++ b/src/m_redirs.c @@ -10,6 +10,7 @@ /* */ /* ************************************************************************** */ +#include #include #include #include @@ -19,32 +20,40 @@ #include "s_line.h" #include "s_struct.h" -void - dup_redirs(const t_com *ptr, - t_msh *msh) +void dup_redirs(const t_com *ptr, t_msh *msh) { int32_t fd; if (ptr->redir == -1) { if ((fd = open(ptr->rdrpath, O_RDONLY)) == -1) + { f_redir(ptr->rdrpath, msh); + return ; + } + ft_printf("[%s]", ptr->rdrpath); dup2(fd, STDIN_FILENO); close(fd); } - if (ptr->redir == 1) + else if (ptr->redir == 1) { if ((fd = open(ptr->rdrpath, - O_CREAT | O_TRUNC | O_WRONLY, 0644)) == -1) + O_CREAT | O_TRUNC | O_WRONLY, 0644)) == -1) + { f_redir(ptr->rdrpath, msh); + return ; + } dup2(fd, ptr->rdrfd); close(fd); } - if (ptr->redir == 2) + else if (ptr->redir == 2) { if ((fd = open(ptr->rdrpath, - O_CREAT | O_APPEND | O_WRONLY, 0644)) == -1) + 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_lblock.c b/src/p_lblock.c index 377757d..3acae1a 100644 --- a/src/p_lblock.c +++ b/src/p_lblock.c @@ -86,7 +86,6 @@ static void int8_t p_get_redir(const char word[], t_com **com) { - /* TODO: norme */ char *ptr; ptr = (char *)word; @@ -103,9 +102,7 @@ int8_t break ; } ptr++; - /* TODO: handle correctly multiples "msh ~> echo qwe > qwe > asd >> zxc > qweasdzxc" */ - /* hint: bash only handles the last one */ - /* TODO: handle "msh ~> cat < Makefile >qwe" | gl hf */ + /* gl hf */ } if ((*com)->redir > 0) { diff --git a/src/s_struct.h b/src/s_struct.h index f47eda0..84271de 100644 --- a/src/s_struct.h +++ b/src/s_struct.h @@ -46,8 +46,8 @@ typedef struct s_com { char **argv; char **env_fork; - char *rdrpath; char *bin; + char *rdrpath; int32_t rdrfd; int8_t redir; } t_com; -- cgit v1.2.3