1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
|
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* e_pipes_next.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 <stdlib.h>
#include <fcntl.h>
#include <unistd.h>
#include <errno.h>
#include "e_redirs.h"
#include "e_unshebanged.h"
#include "f_fail.h"
#include "s_com.h"
#include "s_destroy.h"
#include "s_line.h"
#include "s_lpipes.h"
#include "s_struct.h"
#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);
}
static void e_exec_child(const char fullpath[], t_com *ptr, t_msh *msh)
{
char buff[7];
int fd;
if ((fd = open(fullpath, O_RDONLY)) != -1)
{
if (read(fd, buff, 7) != -1)
if (ft_strncmp(buff, "\177ELF\002\001\001", 7) != 0
&& ft_strncmp(buff, "#!", 2) != 0)
{
close(fd);
e_extern_read_script(fullpath, ptr, msh, TRUE);
return ;
}
close(fd);
}
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);
}
}
void e_pipe_child(char fullpath[],
unsigned char fp_ret,
t_com *ptr,
t_msh *msh)
{
unsigned char bu_id;
unsigned char ret;
e_dup_redirs(ptr, msh);
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);
exit(ret);
}
else
{
if (fp_ret == 2)
e_fullpath_not_found(ptr, msh);
e_exec_child(fullpath, ptr, msh);
}
}
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)
{
rptr = rptr->next;
pipes++;
}
return (pipes);
}
void e_close_unused_fds(int fd[256][2], size_t pipes)
{
size_t i;
i = 0;
while (i < pipes && i < 255)
{
close(fd[i][E_WRITE_END]);
close(fd[i][E_READ_END]);
i++;
}
}
|