summaryrefslogtreecommitdiffstats
path: root/src/c_ctrls.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/c_ctrls.c')
-rw-r--r--src/c_ctrls.c23
1 files changed, 21 insertions, 2 deletions
diff --git a/src/c_ctrls.c b/src/c_ctrls.c
index f841705..58b4517 100644
--- a/src/c_ctrls.c
+++ b/src/c_ctrls.c
@@ -11,6 +11,7 @@
/* ************************************************************************** */
#include <signal.h>
+#include <stdlib.h>
#include <libft.h>
#include <unistd.h>
#include <term.h>
@@ -18,6 +19,9 @@
#include "c_ctrls.h"
#include "c_utils.h"
#include "m_prompt.h"
+#include "m_loop.h"
+#include "s_destroy.h"
+#include "u_utils.h"
t_msh *c_get_msh(int mode, t_msh *src)
{
@@ -30,11 +34,25 @@ t_msh *c_get_msh(int mode, t_msh *src)
return (msh);
}
+short c_ctrl_d(t_msh *msh)
+{
+ int tmp;
+
+ c_set_term_raw(0);
+ write(STDERR_FILENO, "exit\n", 5);
+ u_eof_fd(msh->fd);
+ m_dump_hist(msh->curr_hist_ptr, msh);
+ tmp = msh->ret;
+ s_destroy(msh);
+ exit(tmp);
+ return (1);
+}
+
short c_ctrl_l(char *line, t_caps *tcaps, t_msh *msh)
{
tputs(tgetstr("cl", NULL), 1, ft_putchar);
m_prompt_psx(1, msh);
- c_redraw_line(line, tcaps, msh);
+ c_redraw_line(line, tcaps);
return (1);
}
@@ -44,7 +62,8 @@ char *c_ctrl_c(char **line, char *buf, t_msh *msh)
buf[0] = '\n';
write(1, "\n", 1);
ft_memdel((void**)line);
- return (ft_strdup("\0"));
+ *line = ft_strdup("\0");
+ return (NULL);
}
void c_signal_int(int signo)