summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--src/e_externs.c20
-rw-r--r--src/e_pipes_next.c39
-rw-r--r--src/e_unshebanged.c75
-rw-r--r--src/e_unshebanged.h25
4 files changed, 148 insertions, 11 deletions
diff --git a/src/e_externs.c b/src/e_externs.c
index a3d3594..7b25516 100644
--- a/src/e_externs.c
+++ b/src/e_externs.c
@@ -15,6 +15,7 @@
#include <stdint.h>
#include <stdlib.h>
#include <string.h>
+#include <fcntl.h>
#include <unistd.h>
#include <limits.h>
#include <errno.h>
@@ -23,6 +24,7 @@
#include "d_define.h"
#include "f_fail.h"
#include "e_redirs.h"
+#include "e_unshebanged.h"
#include "s_com.h"
#include "s_destroy.h"
#include "s_line.h"
@@ -32,6 +34,21 @@
static void e_extern_child(const char fullpath[], t_com *ptr, t_msh *msh)
{
+ char buff[7];
+ int32_t 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, FALSE);
+ return ;
+ }
+ close(fd);
+ }
if (execve(fullpath, ptr->argv, msh->envp) == -1)
{
f_exec(fullpath, ptr->bin);
@@ -103,7 +120,8 @@ void e_extern(t_com *ptr, t_msh *msh)
uint8_t fp_ret;
fullpath[0] = C_NUL;
- if (ft_ischarset("./", ptr->bin[0]) == TRUE)
+ if (ptr->bin != NULL && (ft_ischarset("./", ptr->bin[0]) == TRUE
+ || ft_strchr(ptr->bin, '/') != NULL))
{
ft_strlcpy(fullpath, ptr->bin, PATH_MAX);
e_exec_path(fullpath, ptr, 0, msh);
diff --git a/src/e_pipes_next.c b/src/e_pipes_next.c
index b39df15..291ba62 100644
--- a/src/e_pipes_next.c
+++ b/src/e_pipes_next.c
@@ -13,10 +13,12 @@
#include <libft.h>
#include <stdlib.h>
#include <stdint.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"
@@ -37,15 +39,33 @@ static void e_fullpath_not_found(t_com *ptr, t_msh *msh)
exit(127);
}
-static void e_execve_failed(const char fullpath[], t_com *ptr, t_msh *msh)
+static void e_exec_child(const char fullpath[], t_com *ptr, t_msh *msh)
{
- 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);
+ char buff[7];
+ int32_t 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[], uint8_t fp_ret, t_com *ptr, t_msh *msh)
@@ -69,8 +89,7 @@ void e_pipe_child(char fullpath[], uint8_t fp_ret, t_com *ptr, t_msh *msh)
{
if (fp_ret == 2)
e_fullpath_not_found(ptr, msh);
- else if (execve(fullpath, ptr->argv, msh->envp) == -1)
- e_execve_failed(fullpath, ptr, msh);
+ e_exec_child(fullpath, ptr, msh);
}
}
diff --git a/src/e_unshebanged.c b/src/e_unshebanged.c
new file mode 100644
index 0000000..3fd8fac
--- /dev/null
+++ b/src/e_unshebanged.c
@@ -0,0 +1,75 @@
+/* ************************************************************************** */
+/* */
+/* ::: :::::::: */
+/* e_unshebanged.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 <unistd.h>
+#include <limits.h>
+#include <errno.h>
+
+#include "f_fail.h"
+#include "s_struct.h"
+#include "s_com.h"
+#include "s_destroy.h"
+#include "s_line.h"
+#include "s_lpipes.h"
+#include "u_utils.h"
+
+static char **e_get_new_argv(const char fullpath[], t_com *ptr, t_msh *msh)
+{
+ char **argv;
+ size_t i;
+
+ if ((argv = (char**)malloc((3 +
+ u_builtins_get_argc((const char**)ptr->argv)) * sizeof(char*))) == NULL)
+ f_alloc_and_destroy_msh(msh);
+ if ((argv[0] = ft_strdup(msh->argv[0])) == NULL
+ || (argv[1] = ft_strdup(fullpath)) == NULL)
+ {
+ ft_memdel((void*)&argv);
+ f_alloc_and_destroy_msh(msh);
+ }
+ i = 2;
+ while (ptr->argv[i - 2] != NULL)
+ {
+ if ((argv[i] = ft_strdup(ptr->argv[i - 2])) == NULL)
+ {
+ ft_memdel((void*)&argv);
+ f_alloc_and_destroy_msh(msh);
+ }
+ i++;
+ }
+ argv[i] = NULL;
+ return (argv);
+}
+
+void e_extern_read_script(const char fullpath[],
+ t_com *ptr,
+ t_msh *msh,
+ t_bool pipe)
+{
+ char **argv;
+
+ argv = e_get_new_argv(fullpath, ptr, msh);
+ if (execve(msh->argv[0], (char* const *)argv, msh->envp) == -1)
+ {
+ f_exec(msh->argv[0], argv[0]);
+ ft_delwords(argv);
+ u_eof_fd(msh->fd);
+ s_com_destroy(&msh->com);
+ if (pipe == TRUE)
+ s_lpipes_clear(&msh->pipes);
+ s_line_clear(&msh->curr);
+ s_destroy(msh);
+ exit(errno);
+ }
+}
diff --git a/src/e_unshebanged.h b/src/e_unshebanged.h
new file mode 100644
index 0000000..d9499ef
--- /dev/null
+++ b/src/e_unshebanged.h
@@ -0,0 +1,25 @@
+/* ************************************************************************** */
+/* */
+/* ::: :::::::: */
+/* e_unshebanged.h :+: :+: :+: */
+/* +:+ +:+ +:+ */
+/* 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 */
+/* */
+/* ************************************************************************** */
+
+#ifndef FT_E_UNSHEBANGED_H
+#define FT_E_UNSHEBANGED_H
+
+#include <libft.h>
+
+#include "s_struct.h"
+
+void e_extern_read_script(const char fullpath[],
+ t_com *ptr,
+ t_msh *msh,
+ t_bool pipe);
+
+#endif