summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorsalad <fmoenne-@student.le-101.fr>2020-12-15 17:15:58 +0100
committersalad <fmoenne-@student.le-101.fr>2020-12-15 17:15:58 +0100
commit658e858cee47e54b8e3023f50d4f972a9ac55f0f (patch)
tree5227bb7de28efaa19e9a61da67335f0212b6ae20
parentnorm and fix ctrl_c to fit c_gnl rewrite (diff)
download42-minishell-658e858cee47e54b8e3023f50d4f972a9ac55f0f.tar.gz
42-minishell-658e858cee47e54b8e3023f50d4f972a9ac55f0f.tar.bz2
42-minishell-658e858cee47e54b8e3023f50d4f972a9ac55f0f.tar.xz
42-minishell-658e858cee47e54b8e3023f50d4f972a9ac55f0f.tar.zst
42-minishell-658e858cee47e54b8e3023f50d4f972a9ac55f0f.zip
norm tobecontinued
-rw-r--r--src/c_ctrls.c18
-rw-r--r--src/c_ctrls.h1
-rw-r--r--src/c_init.c18
3 files changed, 23 insertions, 14 deletions
diff --git a/src/c_ctrls.c b/src/c_ctrls.c
index 9431f72..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,6 +34,20 @@ 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);
diff --git a/src/c_ctrls.h b/src/c_ctrls.h
index 63710a0..d4b932b 100644
--- a/src/c_ctrls.h
+++ b/src/c_ctrls.h
@@ -20,6 +20,7 @@ void c_signal_int(int signo);
void c_signal_ign(int signo);
t_msh *c_get_msh(int mode, t_msh *src);
short c_ctrl_l(char *line, t_caps *tcaps, t_msh *msh);
+short c_ctrl_d(t_msh *msh);
char *c_ctrl_c(char **line, char *buf, t_msh *msh);
#endif
diff --git a/src/c_init.c b/src/c_init.c
index 93f6bb3..0994e5d 100644
--- a/src/c_init.c
+++ b/src/c_init.c
@@ -60,8 +60,6 @@ short
static short
c_read_cap(char *buf, char *line, t_caps *tcaps, t_msh *msh)
{
- int tmp;
-
if (((*((unsigned int *)buf)) == LEFT_K) ||
((*((unsigned int *)buf)) == CTRL_B))
return (c_key_left(tcaps->plen, tcaps));
@@ -78,18 +76,8 @@ static short
return (c_ctrl_l(line, tcaps, msh));
else if ((*((unsigned int *)buf)) == CTRL_D &&
line[0] == '\0')
- {
- 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 (0);
- }
- else
- return (0);
+ return (c_ctrl_d(msh));
+ return (0);
}
char *ft_strrbavchr(const char *s, int c, size_t start)
@@ -145,6 +133,8 @@ char *c_set_ptr(t_bool reset, char key, t_msh *msh)
return (p);
}
+/* TODO : key_up_down should manage and set the correct key */
+
static char
*c_process_key(char **line, char *buf, t_caps *tcaps, t_msh *msh)
{