summaryrefslogtreecommitdiffstats
path: root/src/e_line.c
diff options
context:
space:
mode:
authorJozanLeClerc <bousset.rudy@gmail.com>2020-08-12 20:43:30 +0200
committerJozanLeClerc <bousset.rudy@gmail.com>2020-08-12 20:43:30 +0200
commitff116f01c3680d0e5d8c32dd9978ed05a37f800c (patch)
tree73765e5ac7ea4ec8af461f44f6d8288fdad6fd82 /src/e_line.c
parentLots of stuff to do (diff)
download42-minishell-ff116f01c3680d0e5d8c32dd9978ed05a37f800c.tar.gz
42-minishell-ff116f01c3680d0e5d8c32dd9978ed05a37f800c.tar.bz2
42-minishell-ff116f01c3680d0e5d8c32dd9978ed05a37f800c.tar.xz
42-minishell-ff116f01c3680d0e5d8c32dd9978ed05a37f800c.tar.zst
42-minishell-ff116f01c3680d0e5d8c32dd9978ed05a37f800c.zip
FeelsCleanMan
Diffstat (limited to 'src/e_line.c')
-rw-r--r--src/e_line.c61
1 files changed, 61 insertions, 0 deletions
diff --git a/src/e_line.c b/src/e_line.c
new file mode 100644
index 0000000..4489926
--- /dev/null
+++ b/src/e_line.c
@@ -0,0 +1,61 @@
+/* ************************************************************************** */
+/* */
+/* ::: :::::::: */
+/* e_line.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 <stdint.h>
+#include <unistd.h>
+
+#include "e_builtins.h"
+#include "e_externs.h"
+#include "e_pipes.h"
+#include "s_lpipes.h"
+#include "s_struct.h"
+
+static uint8_t
+ get_builtin_id(const char bin[],
+ t_msh *msh)
+{
+ uint8_t i;
+
+ i = 0;
+ while (msh->bu_ref[i] && ft_strncmp(bin, msh->bu_ref[i],
+ ft_strlen(msh->bu_ref[i]) + 1) != 0)
+ {
+ i++;
+ }
+ return (i);
+}
+
+void
+ e_line(t_msh *msh)
+{
+ t_line *ptr;
+ uint8_t bu_id;
+
+ ptr = msh->curr;
+ while (ptr != NULL)
+ {
+ if (ptr->pipes)
+ {
+ e_pipes(ptr, msh);
+ }
+ else if (ptr->com)
+ {
+ if ((bu_id = get_builtin_id(ptr->com->bin, msh))
+ < FT_BUILTINS_COUNT)
+ e_builtin(ptr->com, bu_id, msh);
+ else
+ e_extern(ptr->com, msh);
+ }
+ ptr = ptr->next;
+ }
+}