summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Makefile1
-rw-r--r--src/ft_b_echo.c2
-rw-r--r--src/ft_b_echo.h4
-rw-r--r--src/ft_b_env.c9
-rw-r--r--src/ft_b_env.h4
-rw-r--r--src/ft_d_define.h13
-rw-r--r--src/ft_e_lcom.c2
-rw-r--r--src/ft_e_lcom.h2
-rw-r--r--src/ft_f_fail.c36
-rw-r--r--src/ft_f_fail.h19
-rw-r--r--src/ft_m_funptr.c3
-rw-r--r--src/ft_m_loop.c2
-rw-r--r--src/ft_m_loop.h2
-rw-r--r--src/ft_p_line.c3
-rw-r--r--src/ft_s_struct.h4
-rw-r--r--src/minishell.c4
16 files changed, 94 insertions, 16 deletions
diff --git a/Makefile b/Makefile
index 9134da9..a7267d9 100644
--- a/Makefile
+++ b/Makefile
@@ -18,6 +18,7 @@ SRCS_NAME = minishell.c
SRCS_NAME += ft_b_echo.c
SRCS_NAME += ft_b_env.c
SRCS_NAME += ft_e_lcom.c
+SRCS_NAME += ft_f_fail.c
SRCS_NAME += ft_m_funptr.c
SRCS_NAME += ft_m_loop.c
SRCS_NAME += ft_m_prompt.c
diff --git a/src/ft_b_echo.c b/src/ft_b_echo.c
index d5e4a64..326967d 100644
--- a/src/ft_b_echo.c
+++ b/src/ft_b_echo.c
@@ -14,7 +14,7 @@
#include <stdint.h>
#include "ft_s_struct.h"
-int32_t
+uint8_t
ft_b_echo(char *args[],
t_msh *msh)
{
diff --git a/src/ft_b_echo.h b/src/ft_b_echo.h
index 07da189..7fd7463 100644
--- a/src/ft_b_echo.h
+++ b/src/ft_b_echo.h
@@ -16,7 +16,7 @@
#include <stdint.h>
#include "ft_s_struct.h"
-int32_t ft_b_echo(char *args[],
- t_msh *msh);
+uint8_t ft_b_echo(char *args[],
+ t_msh *msh);
#endif
diff --git a/src/ft_b_env.c b/src/ft_b_env.c
index eb3b107..d3df62d 100644
--- a/src/ft_b_env.c
+++ b/src/ft_b_env.c
@@ -13,15 +13,20 @@
#include <libft.h>
#include <stdint.h>
#include "ft_b_env.h"
+#include "ft_f_fail.h"
#include "ft_s_struct.h"
-int32_t
+uint8_t
ft_b_env(char *args[],
t_msh *msh)
{
char **ptr;
- (void)args;
+ if (args[0])
+ {
+ ft_fail_no_options("env");
+ return (127);
+ }
ptr = msh->envp;
while (*ptr)
{
diff --git a/src/ft_b_env.h b/src/ft_b_env.h
index 3e843b0..192c5d9 100644
--- a/src/ft_b_env.h
+++ b/src/ft_b_env.h
@@ -16,7 +16,7 @@
#include <stdint.h>
#include "ft_s_struct.h"
-int32_t ft_b_env(char *args[],
- t_msh *msh);
+uint8_t ft_b_env(char *args[],
+ t_msh *msh);
#endif
diff --git a/src/ft_d_define.h b/src/ft_d_define.h
index b30be21..e5ef970 100644
--- a/src/ft_d_define.h
+++ b/src/ft_d_define.h
@@ -13,8 +13,21 @@
#ifndef FT_D_DEFINE_H
#define FT_D_DEFINE_H
+#include "ft_d_enum.h"
+
+/*
+** ====== CLASSICS ======
+*/
+
#define FT_PS_ONE "minishell ~> "
#define FT_BUILTINS "echo|cd|pwd|export|unset|env|exit|cat"
#define FT_BUILTINS_COUNT 8
+/*
+** ====== FAIL MSG ======
+*/
+
+#define FT_FAIL_ALLOC "failed to allocate memory"
+#define FT_FAIL_NO_OPTIONS "no options required"
+
#endif
diff --git a/src/ft_e_lcom.c b/src/ft_e_lcom.c
index b928004..409cbb1 100644
--- a/src/ft_e_lcom.c
+++ b/src/ft_e_lcom.c
@@ -29,7 +29,7 @@ static uint8_t
return (i);
}
-int32_t
+uint8_t
ft_e_lcom(t_msh *msh)
{
t_lcom *ptr;
diff --git a/src/ft_e_lcom.h b/src/ft_e_lcom.h
index ccb1db4..5724544 100644
--- a/src/ft_e_lcom.h
+++ b/src/ft_e_lcom.h
@@ -16,6 +16,6 @@
#include <stdint.h>
#include "ft_s_struct.h"
-int32_t ft_e_lcom(t_msh *msh);
+uint8_t ft_e_lcom(t_msh *msh);
#endif
diff --git a/src/ft_f_fail.c b/src/ft_f_fail.c
new file mode 100644
index 0000000..aed16d0
--- /dev/null
+++ b/src/ft_f_fail.c
@@ -0,0 +1,36 @@
+/* ************************************************************************** */
+/* */
+/* ::: :::::::: */
+/* ft_f_fail.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 "ft_d_define.h"
+
+static void
+ ft_write_fail(const char concern[],
+ const char msg[])
+{
+ ft_dprintf(STDERR_FILENO, "%s: %s\n", concern, msg);
+}
+
+void
+ ft_fail_no_options(const char concern[])
+{
+ ft_write_fail(concern, FT_FAIL_NO_OPTIONS);
+}
+
+void
+ ft_fail_alloc(void)
+{
+ ft_write_fail("minishell", FT_FAIL_ALLOC);
+ exit(FT_RET_ALLOC);
+}
diff --git a/src/ft_f_fail.h b/src/ft_f_fail.h
new file mode 100644
index 0000000..f34fd25
--- /dev/null
+++ b/src/ft_f_fail.h
@@ -0,0 +1,19 @@
+/* ************************************************************************** */
+/* */
+/* ::: :::::::: */
+/* ft_f_fail.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_F_FAIL_H
+#define FT_F_FAIL_H
+
+void ft_fail_no_options(const char concern[]);
+void ft_fail_alloc(void);
+
+#endif
diff --git a/src/ft_m_funptr.c b/src/ft_m_funptr.c
index a9e7882..813e5a3 100644
--- a/src/ft_m_funptr.c
+++ b/src/ft_m_funptr.c
@@ -15,6 +15,7 @@
#include "ft_b_echo.h"
#include "ft_b_env.h"
#include "ft_d_enum.h"
+#include "ft_f_fail.h"
#include "ft_m_funptr.h"
#include "ft_s_struct.h"
@@ -31,6 +32,6 @@ void
/* msh->bu_ptr[7] = ft_b_cat; */
if (!(msh->bu_ref = ft_split(FT_BUILTINS, '|')))
{
- exit(FT_RET_ALLOC);
+ ft_fail_alloc();
}
}
diff --git a/src/ft_m_loop.c b/src/ft_m_loop.c
index 10a4f5e..b156b08 100644
--- a/src/ft_m_loop.c
+++ b/src/ft_m_loop.c
@@ -20,7 +20,7 @@
#include "ft_p_line.h"
#include "ft_s_lcom.h"
-int32_t
+uint8_t
ft_m_loop(t_msh *msh)
{
int8_t gnl;
diff --git a/src/ft_m_loop.h b/src/ft_m_loop.h
index 564d447..b7a6b12 100644
--- a/src/ft_m_loop.h
+++ b/src/ft_m_loop.h
@@ -16,6 +16,6 @@
#include <stdint.h>
#include "ft_s_struct.h"
-int32_t ft_m_loop(t_msh *msh);
+uint8_t ft_m_loop(t_msh *msh);
#endif
diff --git a/src/ft_p_line.c b/src/ft_p_line.c
index f299f64..df31973 100644
--- a/src/ft_p_line.c
+++ b/src/ft_p_line.c
@@ -13,6 +13,7 @@
#include <libft.h>
#include <stdlib.h>
#include "ft_d_enum.h"
+#include "ft_f_fail.h"
#include "ft_p_lcom.h"
#include "ft_p_line.h"
#include "ft_s_struct.h"
@@ -36,6 +37,6 @@ void
}
if (ft_p_lcom(line, count, msh) < 0)
{
- exit(FT_RET_ALLOC);
+ ft_fail_alloc();
}
}
diff --git a/src/ft_s_struct.h b/src/ft_s_struct.h
index 9719a6f..1f062c2 100644
--- a/src/ft_s_struct.h
+++ b/src/ft_s_struct.h
@@ -27,9 +27,9 @@ typedef struct s_msh
{
char *ps_one;
char **envp;
- int32_t ret;
+ uint8_t ret;
char **bu_ref;
- int32_t (*bu_ptr[FT_BUILTINS_COUNT])(char **, struct s_msh*);
+ uint8_t (*bu_ptr[FT_BUILTINS_COUNT])(char **, struct s_msh*);
struct s_lcom *curr;
} t_msh;
diff --git a/src/minishell.c b/src/minishell.c
index 4b8e763..fc4c4be 100644
--- a/src/minishell.c
+++ b/src/minishell.c
@@ -14,6 +14,7 @@
#include <stdint.h>
#include "minishell.h"
#include "ft_d_enum.h"
+#include "ft_f_fail.h"
#include "ft_m_loop.h"
#include "ft_s_struct.h"
#include "ft_s_init.h"
@@ -31,7 +32,7 @@ int
(void)argv;
if (!(msh = ft_init_msh(envp)))
{
- return (FT_RET_ALLOC);
+ ft_fail_alloc();
}
msh->ret = ft_m_loop(msh);
ret = msh->ret;
@@ -47,6 +48,7 @@ int
** b_ -> builtins related
** d_ -> defines related
** e_ -> exec related
+** f_ -> failure related
** m_ -> core minishell related
** p_ -> parse related
** s_ -> structs related