/* ************************************************************************** */ /* */ /* ::: :::::::: */ /* 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_e_lcom.h" #include "ft_m_loop.h" #include "ft_m_prompt.h" #include "ft_p_line.h" #include "ft_s_lcom.h" uint8_t ft_m_loop(t_msh *msh) { char *line; int8_t gnl; gnl = 1; while (gnl > 0) { ft_m_prompt(msh); gnl = get_next_line(STDIN_FILENO, &line); if (line[0] != '\0') { ft_p_line(line, msh); ft_memdel((void*)&line); ft_e_lcom(msh); ft_lcom_clear(&msh->curr); /* TODO: handle segv on spaces only "msh ~> " */ /* TODO: GNL 25 leak on "msh ~> exit" */ /* TODO: "msh ~> some command \": re GNL into ft_nrealloc */ /* TODO: the chad pipes | */ } else { ft_memdel((void*)&line); } } return (FT_RET_FINE); }