summaryrefslogtreecommitdiffstats
path: root/src/e_pipes.c
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--src/e_pipes.c162
1 files changed, 65 insertions, 97 deletions
diff --git a/src/e_pipes.c b/src/e_pipes.c
index 7b07789..f9c9f72 100644
--- a/src/e_pipes.c
+++ b/src/e_pipes.c
@@ -17,101 +17,67 @@
#include <unistd.h>
#include "e_builtins.h"
-#include "e_redirs.h"
+#include "e_pipes_next.h"
#include "f_fail.h"
-#include "s_destroy.h"
-#include "s_line.h"
#include "s_lpipes.h"
#include "s_struct.h"
#include "u_utils.h"
#include "u_path.h"
/*
-** TODO: handle execve failed
+** TODO: handle fork() failed, etc
*/
-static void e_pipe_child(char *fullpath[],
- uint8_t pipe_id,
- t_com *ptr,
- t_msh *msh)
+static int32_t e_unroll_pipes(int32_t fd[256][2],
+ char *fullpath[],
+ size_t pipes,
+ t_msh *msh)
{
- uint8_t bu_id;
- uint8_t ret;
+ struct s_lpipes *head;
+ int32_t pid;
+ uint16_t i;
- e_dup_redirs(ptr, msh);
- if (ft_strncmp(fullpath[pipe_id], "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_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);
-}
-
-static size_t e_get_pipes_count(struct s_lpipes *ptr)
-{
- struct s_lpipes *rptr;
- size_t pipes;
-
- rptr = ptr;
- pipes = 0;
- while (rptr->next != NULL)
+ head = msh->pipes;
+ i = 0;
+ while (i <= pipes && i < 255)
{
- rptr = rptr->next;
- pipes++;
+ if ((pid = fork()) == 0)
+ {
+ if (i != 0)
+ dup2(fd[i - 1][E_WRITE_END], STDIN_FILENO);
+ if (i != pipes)
+ dup2(fd[i][E_READ_END], STDOUT_FILENO);
+ e_close_unused_fds(fd, pipes);
+ e_pipe_child(fullpath, i, head->com, msh);
+ }
+ head = head->next;
+ i++;
}
- return (pipes);
+ return (pid);
}
/*
** TODO: error mgmnt
*/
-static void e_pipe_exec_path(char *fullpath[], struct s_lpipes *head, t_msh *msh)
+static void e_pipe_exec_path(char *fullpath[],
+ size_t pipes,
+ t_msh *msh)
{
- int fd[256][2];
- size_t pipes;
- size_t i;
- size_t j;
- int pid;
- int status;
+ int32_t fd[256][2];
+ int32_t pid;
+ int32_t status;
+ uint16_t i;
- pipes = e_get_pipes_count(head);
i = 0;
- while (i < pipes)
+ while (i < pipes && i < 255)
{
pipe(fd[i]);
i++;
}
+ pid = e_unroll_pipes(fd, fullpath, pipes, msh);
i = 0;
- while (i <= pipes)
- {
- if ((pid = fork()) == 0)
- {
- if (i != 0)
- dup2(fd[i - 1][E_WRITE_END], STDIN_FILENO);
- if (i != pipes)
- dup2(fd[i][E_READ_END], STDOUT_FILENO);
- j = 0;
- while (j < pipes)
- {
- close(fd[j][E_WRITE_END]);
- close(fd[j][E_READ_END]);
- j++;
- }
- e_pipe_child(fullpath, i, head->com, msh);
- }
- head = head->next;
- i++;
- }
- i = 0;
- while (i < pipes)
+ while (i < pipes && i < 255)
{
close(fd[i][E_WRITE_END]);
close(fd[i][E_READ_END]);
@@ -121,20 +87,39 @@ static void e_pipe_exec_path(char *fullpath[], struct s_lpipes *head, t_msh *ms
msh->ret = WEXITSTATUS(status);
}
+static char *e_get_current_path(struct s_lpipes *rptr, t_msh *msh)
+{
+ char tmp[PATH_MAX];
+ char *path;
-
-
-
-
-
+ path = NULL;
+ if (rptr->com->bin != NULL && ft_ischarset("/.", rptr->com->bin[0]) == TRUE)
+ {
+ if ((path = ft_strdup(rptr->com->bin)) == NULL)
+ f_alloc_and_destroy_msh(msh);
+ }
+ else
+ {
+ if (u_get_builtin_id(rptr->com->bin) < B_BUILTINS_COUNT)
+ {
+ if ((path = ft_strdup("builtin")) == NULL)
+ f_alloc_and_destroy_msh(msh);
+ }
+ else
+ {
+ u_search_in_path(tmp, rptr->com->bin, PATH_MAX, msh);
+ if ((path = ft_strdup(tmp)) == NULL)
+ f_alloc_and_destroy_msh(msh);
+ }
+ }
+ return (path);
+}
static char **e_get_fullpath(size_t pipes, t_msh *msh)
{
struct s_lpipes *rptr;
- char tmp[PATH_MAX];
char **fullpath;
size_t i;
- uint8_t bu_id;
rptr = msh->pipes;
if ((fullpath = (char **)malloc((pipes + 2) * sizeof(char *))) == NULL)
@@ -143,25 +128,7 @@ static char **e_get_fullpath(size_t pipes, t_msh *msh)
i = 0;
while (rptr != NULL)
{
- if (ft_ischarset("/.", rptr->com->bin[0]) == TRUE)
- {
- if ((fullpath[i] = ft_strdup(rptr->com->bin)) == NULL)
- f_alloc_and_destroy_msh(msh);
- }
- else
- {
- if ((bu_id = u_get_builtin_id(rptr->com->bin))
- < B_BUILTINS_COUNT)
- {
- if ((fullpath[i] = ft_strdup("builtin")) == NULL)
- f_alloc_and_destroy_msh(msh);
- }
- else
- {
- u_search_in_path(tmp, rptr->com->bin, PATH_MAX, msh);
- fullpath[i] = ft_strdup(tmp);
- }
- }
+ fullpath[i] = e_get_current_path(rptr, msh);
i++;
rptr = rptr->next;
}
@@ -170,10 +137,11 @@ static char **e_get_fullpath(size_t pipes, t_msh *msh)
void e_pipes(t_msh *msh)
{
- char **fullpath;
+ const size_t pipes = e_get_pipes_count(msh->pipes);
+ char **fullpath;
- fullpath = e_get_fullpath(e_get_pipes_count(msh->pipes), msh);
- e_pipe_exec_path(fullpath, msh->pipes, msh);
+ fullpath = e_get_fullpath(pipes, msh);
+ e_pipe_exec_path(fullpath, pipes, msh);
ft_delwords(fullpath);
s_lpipes_clear(&msh->pipes);
}