summaryrefslogtreecommitdiffstats
path: root/src/e_pipes_next.c
diff options
context:
space:
mode:
authorJozanLeClerc <bousset.rudy@gmail.com>2020-10-05 15:43:33 +0200
committerJozanLeClerc <bousset.rudy@gmail.com>2020-10-05 15:43:33 +0200
commit7c82cd4d8f2d78adca2db968edfec2381db108df (patch)
tree90b7e1886134b614d73dfc26a18af29655921a6a /src/e_pipes_next.c
parentPipes rework incomming (diff)
download42-minishell-7c82cd4d8f2d78adca2db968edfec2381db108df.tar.gz
42-minishell-7c82cd4d8f2d78adca2db968edfec2381db108df.tar.bz2
42-minishell-7c82cd4d8f2d78adca2db968edfec2381db108df.tar.xz
42-minishell-7c82cd4d8f2d78adca2db968edfec2381db108df.tar.zst
42-minishell-7c82cd4d8f2d78adca2db968edfec2381db108df.zip
pipes update
Diffstat (limited to '')
-rw-r--r--src/e_pipes_next.c35
1 files changed, 31 insertions, 4 deletions
diff --git a/src/e_pipes_next.c b/src/e_pipes_next.c
index b3482c3..90e64f9 100644
--- a/src/e_pipes_next.c
+++ b/src/e_pipes_next.c
@@ -14,8 +14,11 @@
#include <stdlib.h>
#include <stdint.h>
#include <unistd.h>
+#include <errno.h>
#include "e_redirs.h"
+#include "f_fail.h"
+#include "s_com.h"
#include "s_destroy.h"
#include "s_line.h"
#include "s_lpipes.h"
@@ -23,29 +26,53 @@
#include "u_utils.h"
#include "u_utils.h"
+static void e_fullpath_not_found(t_com *ptr, t_msh *msh)
+{
+ f_command_not_found(ptr->bin);
+ u_eof_fd(msh->fd);
+ s_com_destroy(&msh->com);
+ s_lpipes_clear(&msh->pipes);
+ s_line_clear(&msh->curr);
+ s_destroy(msh);
+ exit(127);
+}
+
/*
** TODO: handle execve failed
*/
-void e_pipe_child(char *fullpath[], uint8_t pipe_id, t_com *ptr, t_msh *msh)
+void e_pipe_child(char fullpath[], uint8_t fp_ret, t_com *ptr, t_msh *msh)
{
uint8_t bu_id;
uint8_t ret;
e_dup_redirs(ptr, msh);
- if (ft_strncmp(fullpath[pipe_id], "builtin", 8) == 0)
+ if (ft_strncmp(fullpath, "builtin", 8) == 0)
{
bu_id = u_get_builtin_id(ptr->bin);
ret = msh->bu_ptr[bu_id](ptr->argv + 1, msh);
u_eof_fd(msh->fd);
+ s_com_destroy(&msh->com);
s_lpipes_clear(&msh->pipes);
s_line_clear(&msh->curr);
s_destroy(msh);
- ft_delwords(fullpath);
exit(ret);
}
else
- execve(fullpath[pipe_id], ptr->argv, msh->envp);
+ {
+ if (fp_ret == 2)
+ e_fullpath_not_found(ptr, msh);
+ if (execve(fullpath, ptr->argv, msh->envp) == -1)
+ {
+ f_exec(fullpath, ptr->bin);
+ u_eof_fd(msh->fd);
+ s_com_destroy(&msh->com);
+ s_lpipes_clear(&msh->pipes);
+ s_line_clear(&msh->curr);
+ s_destroy(msh);
+ exit(errno);
+ }
+ }
}
size_t e_get_pipes_count(struct s_lpipes *ptr)