summaryrefslogtreecommitdiffstats
path: root/src/c_init.c
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--src/c_init.c13
1 files changed, 10 insertions, 3 deletions
diff --git a/src/c_init.c b/src/c_init.c
index beccf8a..5d07ed1 100644
--- a/src/c_init.c
+++ b/src/c_init.c
@@ -19,6 +19,7 @@
#include "c_init.h"
#include "m_prompt.h"
+#include "m_loop.h"
#include "s_struct.h"
static char
@@ -88,7 +89,6 @@ int16_t
int i;
static char *line;
- (void)msh;
i = -1;
if (line == NULL)
if (!(line = ft_calloc(2, sizeof(char))))
@@ -96,7 +96,10 @@ int16_t
if (ft_isprint(buf[0]))
{
if (*buf == 'q')
+ {
+ tputs(tgetstr("ve", NULL), 1, ft_putchar);
exit(0);
+ }
else if (*buf == '\n')
tputs(tgetstr("nl", NULL), 1, ft_putchar);
line = ft_strjoin_m(line, buf);
@@ -112,8 +115,11 @@ int16_t
else if (buf[0] == '\n')
{
write(1, buf, ft_strlen(buf));
- m_prompt_psx(1, msh);
tputs(tgetstr("cr", NULL), 1, ft_putchar);
+ m_parse_and_run_line(line, msh);
+ tputs(tgetstr("cr", NULL), 1, ft_putchar);
+ ft_memdel((void**)&line);
+ m_prompt_psx(1, msh);
return (1);
}
else if (strncmp(buf, tgetstr("kl", NULL), ft_strlen(tgetstr("kl", NULL))) == 0)
@@ -151,8 +157,9 @@ int16_t c_init_tcaps(t_msh *msh)
ft_bzero(nread, 5);
if (!(read(STDIN_FILENO, nread, 4)))
return (0);
+ tputs(tgetstr("vi", NULL), 1, ft_putchar);
ret = c_process_key(msh, nread);
+ tputs(tgetstr("ve", NULL), 1, ft_putchar);
}
- ft_printf("%d\n", ret);
return (1);
}