summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJozanLeClerc <bousset.rudy@gmail.com>2020-05-11 15:52:11 +0200
committerJozanLeClerc <bousset.rudy@gmail.com>2020-05-11 15:52:11 +0200
commit4cdd3e31e7181a10e83e993f92e8d6606e978a2d (patch)
tree2ea42522239dcbb210941635ccc1a23e788e6244
parentUFS reinstall, will finish pipes later (diff)
download42-minishell-4cdd3e31e7181a10e83e993f92e8d6606e978a2d.tar.gz
42-minishell-4cdd3e31e7181a10e83e993f92e8d6606e978a2d.tar.bz2
42-minishell-4cdd3e31e7181a10e83e993f92e8d6606e978a2d.tar.xz
42-minishell-4cdd3e31e7181a10e83e993f92e8d6606e978a2d.tar.zst
42-minishell-4cdd3e31e7181a10e83e993f92e8d6606e978a2d.zip
New files
Diffstat (limited to '')
-rw-r--r--Makefile1
-rw-r--r--src/ft_e_lcom.c10
-rw-r--r--src/ft_e_pipes.c47
-rw-r--r--src/ft_e_pipes.h20
-rw-r--r--src/ft_s_destroy.c1
-rw-r--r--src/ft_s_lpipes.c4
6 files changed, 75 insertions, 8 deletions
diff --git a/Makefile b/Makefile
index ed4e971..758c173 100644
--- a/Makefile
+++ b/Makefile
@@ -26,6 +26,7 @@ SRCS_NAME += e_builtins
SRCS_NAME += e_externs
SRCS_NAME += e_externs_next
SRCS_NAME += e_lcom
+SRCS_NAME += e_pipes
SRCS_NAME += f_chdir
SRCS_NAME += f_errno
SRCS_NAME += f_fail
diff --git a/src/ft_e_lcom.c b/src/ft_e_lcom.c
index 3f5f81a..54db581 100644
--- a/src/ft_e_lcom.c
+++ b/src/ft_e_lcom.c
@@ -11,9 +11,12 @@
/* ************************************************************************** */
#include <libft.h>
+#include <stdint.h>
#include "ft_e_builtins.h"
#include "ft_e_externs.h"
+#include "ft_e_pipes.h"
+#include "ft_s_lpipes.h"
#include "ft_s_struct.h"
static uint8_t
@@ -42,12 +45,7 @@ void
{
if (ptr->pipes)
{
- ft_printf("%s\n", ptr->pipes->one->com);
- if ((bu_id = ft_get_builtin_id(ptr->pipes->one->com, msh))
- < FT_BUILTINS_COUNT)
- ft_e_builtin(ptr->pipes->one, bu_id, msh);
- else
- ft_e_extern(ptr->pipes->one, msh);
+ ft_e_pipes(ptr, msh);
}
else if (ptr->com)
{
diff --git a/src/ft_e_pipes.c b/src/ft_e_pipes.c
new file mode 100644
index 0000000..81c8a08
--- /dev/null
+++ b/src/ft_e_pipes.c
@@ -0,0 +1,47 @@
+/* ************************************************************************** */
+/* */
+/* ::: :::::::: */
+/* ft_e_pipes.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 "ft_e_builtins.h"
+#include "ft_e_externs.h"
+#include "ft_s_lpipes.h"
+#include "ft_s_struct.h"
+
+static uint8_t
+ ft_get_builtin_id(const char com[],
+ t_msh *msh)
+{
+ uint8_t i;
+
+ i = 0;
+ while (msh->bu_ref[i] && ft_strncmp(com, msh->bu_ref[i],
+ ft_strlen(msh->bu_ref[i]) + 1) != 0)
+ {
+ i++;
+ }
+ return (i);
+}
+
+void
+ ft_e_pipes(t_lcom *ptr,
+ t_msh *msh)
+{
+ uint8_t bu_id;
+
+ if ((bu_id = ft_get_builtin_id(ptr->pipes->one->com, msh))
+ < FT_BUILTINS_COUNT)
+ ft_e_builtin(ptr->pipes->one, bu_id, msh);
+ else
+ ft_e_extern(ptr->pipes->one, msh);
+ ft_lpipes_clear(&ptr->pipes);
+}
diff --git a/src/ft_e_pipes.h b/src/ft_e_pipes.h
new file mode 100644
index 0000000..f801b21
--- /dev/null
+++ b/src/ft_e_pipes.h
@@ -0,0 +1,20 @@
+/* ************************************************************************** */
+/* */
+/* ::: :::::::: */
+/* ft_e_pipes.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_PIPES_H
+#define FT_E_PIPES_H
+
+#include "ft_s_struct.h"
+
+void ft_e_pipes(t_lcom *ptr, t_msh *msh);
+
+#endif
diff --git a/src/ft_s_destroy.c b/src/ft_s_destroy.c
index 08980b5..22009c8 100644
--- a/src/ft_s_destroy.c
+++ b/src/ft_s_destroy.c
@@ -22,6 +22,7 @@ void
ft_memdel((void*)&msh->cwd);
ft_memdel((void*)&msh->shname);
ft_delwords(msh->bu_ref);
+ ft_delwords(msh->envp);
ft_lvars_clear(&msh->vars);
ft_memdel((void*)&msh);
}
diff --git a/src/ft_s_lpipes.c b/src/ft_s_lpipes.c
index dcdc2ec..8bd34de 100644
--- a/src/ft_s_lpipes.c
+++ b/src/ft_s_lpipes.c
@@ -82,7 +82,6 @@ struct s_lpipes
t_lcom *lcom,
t_msh *msh)
{
- struct s_lpipes *link;
struct s_lpipes *lpipes;
char **words;
size_t i;
@@ -91,9 +90,10 @@ struct s_lpipes
return (NULL);
i = 0;
if (!(lpipes = (struct s_lpipes*)malloc(sizeof(struct s_lpipes))))
+ return (NULL);
while (words[i])
{
- if (!(link = ft_lpipes_new(words[i], msh)))
+ if (!(lpipes = ft_lpipes_new(words[i], msh)))
{
return (NULL);
}