From 386c44e541af7aa1ba594d2f0a9665199b3dffb4 Mon Sep 17 00:00:00 2001 From: JozanLeClerc Date: Mon, 20 Apr 2020 17:04:59 +0200 Subject: Nice prompt --- src/ft_m_loop.c | 33 +++++++++++++++++++++++++++++++++ src/ft_m_loop.h | 21 +++++++++++++++++++++ src/ft_s_destroy.c | 1 + src/ft_s_init.c | 7 ++++--- src/ft_s_init.h | 2 +- src/ft_s_struct.h | 3 ++- src/minishell.c | 13 +++++++------ 7 files changed, 69 insertions(+), 11 deletions(-) create mode 100644 src/ft_m_loop.c create mode 100644 src/ft_m_loop.h (limited to 'src') diff --git a/src/ft_m_loop.c b/src/ft_m_loop.c new file mode 100644 index 0000000..1e2efc0 --- /dev/null +++ b/src/ft_m_loop.c @@ -0,0 +1,33 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_m_loop.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rbousset +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/02/14 17:19:27 by rbousset #+# #+# */ +/* Updated: 2020/02/14 17:19:29 by rbousset ### ########lyon.fr */ +/* */ +/* ************************************************************************** */ + +#include +#include +#include +#include "ft_d_enum.h" +#include "ft_m_loop.h" +#include "ft_m_prompt.h" + +int32_t + ft_m_loop(t_msh *msh) +{ + int8_t gnl; + char *line; + + gnl = 1; + while (gnl > 0) + { + ft_m_prompt(msh); + gnl = get_next_line(STDIN_FILENO, &line); + } + return (FT_RET_FINE); +} diff --git a/src/ft_m_loop.h b/src/ft_m_loop.h new file mode 100644 index 0000000..564d447 --- /dev/null +++ b/src/ft_m_loop.h @@ -0,0 +1,21 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_m_loop.h :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rbousset +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/02/14 17:19:27 by rbousset #+# #+# */ +/* Updated: 2020/02/14 17:19:29 by rbousset ### ########lyon.fr */ +/* */ +/* ************************************************************************** */ + +#ifndef FT_M_LOOP +#define FT_M_LOOP + +#include +#include "ft_s_struct.h" + +int32_t ft_m_loop(t_msh *msh); + +#endif diff --git a/src/ft_s_destroy.c b/src/ft_s_destroy.c index ef132ce..23e0737 100644 --- a/src/ft_s_destroy.c +++ b/src/ft_s_destroy.c @@ -16,5 +16,6 @@ void ft_s_destroy(t_msh *msh) { + ft_memdel((void*)&msh->ps_one); ft_memdel((void*)&msh); } diff --git a/src/ft_s_init.c b/src/ft_s_init.c index 0d27aa7..c4b2667 100644 --- a/src/ft_s_init.c +++ b/src/ft_s_init.c @@ -15,7 +15,7 @@ #include "ft_s_init.h" t_msh - *ft_init_msh(void) + *ft_init_msh(char *envp[]) { t_msh *msh; @@ -28,8 +28,9 @@ t_msh { return (NULL); } - ft_strlcpy(msh->ps_one, FT_PS_ONE, ft_strlen(FT_PS_ONE)); - msh->envp = NULL; + ft_strlcpy(msh->ps_one, FT_PS_ONE, ft_strlen(FT_PS_ONE) + 1); + msh->envp = envp; + msh->ret = 0; msh->lcom = NULL; return (msh); } diff --git a/src/ft_s_init.h b/src/ft_s_init.h index ea28b24..c5ce54a 100644 --- a/src/ft_s_init.h +++ b/src/ft_s_init.h @@ -16,6 +16,6 @@ #include #include "ft_s_struct.h" -t_msh *ft_init_msh(void); +t_msh *ft_init_msh(char *envp[]); #endif diff --git a/src/ft_s_struct.h b/src/ft_s_struct.h index 3bfa76b..8234449 100644 --- a/src/ft_s_struct.h +++ b/src/ft_s_struct.h @@ -22,9 +22,10 @@ typedef struct s_com typedef struct s_msh { - struct s_com *lcom; char *ps_one; char **envp; + int32_t ret; + struct s_com *lcom; } t_msh; #endif diff --git a/src/minishell.c b/src/minishell.c index 5d97ed6..a3b0354 100644 --- a/src/minishell.c +++ b/src/minishell.c @@ -11,9 +11,10 @@ /* ************************************************************************** */ #include +#include #include "minishell.h" #include "ft_d_enum.h" -#include "ft_m_prompt.h" +#include "ft_m_loop.h" #include "ft_s_struct.h" #include "ft_s_init.h" #include "ft_s_destroy.h" @@ -24,23 +25,23 @@ main(int argc, char *envp[]) { t_msh *msh; + int32_t ret; (void)argc; (void)argv; - (void)envp; - if (!(msh = ft_init_msh())) + if (!(msh = ft_init_msh(envp))) { return (FT_RET_ALLOC); } - msh->envp = envp; - ft_m_prompt(msh); + msh->ret = ft_m_loop(msh); + ret = msh->ret; /* while (*msh->envp) */ /* { */ /* ft_printf("%s\n", *msh->envp); */ /* msh->envp++; */ /* } */ ft_s_destroy(msh); - return (FT_RET_FINE); + return (ret); } /* -- cgit v1.2.3