diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/c_init.c | 12 | ||||
-rw-r--r-- | src/c_input.c | 5 | ||||
-rw-r--r-- | src/c_utils.c | 21 | ||||
-rw-r--r-- | src/c_utils.h | 2 |
4 files changed, 24 insertions, 16 deletions
diff --git a/src/c_init.c b/src/c_init.c index ee6782d..2bc0be3 100644 --- a/src/c_init.c +++ b/src/c_init.c @@ -10,12 +10,12 @@ /* */ /* ************************************************************************** */ - #include <unistd.h> #include <termios.h> #include <stdlib.h> #include <string.h> #include <term.h> +#include <signal.h> #include <libft.h> #include "c_init.h" @@ -71,15 +71,17 @@ int16_t i = -1; if (line == NULL) - if (!(line = ft_calloc(2, sizeof(char)))) - return (0); + { + if (!(line = ft_calloc(1, sizeof(char)))) + return (-1); + } if (ft_isprint(buf[0])) { if (tcaps->cpos == ft_strlen(line)) line = ft_strjoin(line, buf); else line = c_insert_char(line, buf[0], tcaps); - c_redraw_line(line, tcaps->cpos, msh); + c_redraw_line(line, tcaps, msh); tcaps->cpos++; } else @@ -116,6 +118,8 @@ int16_t { return (c_new_line(buf, &line, msh, tcaps)); } + else + return (0); } return (0); } diff --git a/src/c_input.c b/src/c_input.c index ed60ae4..478c29e 100644 --- a/src/c_input.c +++ b/src/c_input.c @@ -20,7 +20,6 @@ #include "m_prompt.h" #include "m_loop.h" - int16_t c_back_slash(char **line, t_caps *tcaps) @@ -42,7 +41,7 @@ int16_t { tputs(tgetstr("cl", NULL), 1, ft_putchar); m_prompt_psx(1, msh); - c_redraw_line(line, tcaps->cpos, msh); + c_redraw_line(line, tcaps, msh); return (1); } @@ -53,7 +52,7 @@ int16_t { tputs(tgetstr("cl", NULL), 1, ft_putchar); m_prompt_psx(1, msh); - c_redraw_line(line, tcaps->cpos, msh); + c_redraw_line(line, tcaps, msh); return (1); } diff --git a/src/c_utils.c b/src/c_utils.c index d5a45e0..43d6452 100644 --- a/src/c_utils.c +++ b/src/c_utils.c @@ -25,9 +25,11 @@ /* ** TODO: ** quotes -** leaks +** leaks on line ** C-c ** tests varies +** NORME +** MULTILIGHNE ** term(0) on exit DONE ** cursor on char insert DONE */ @@ -93,6 +95,7 @@ int16_t { m_parse_and_run_line(*line, msh); *line = NULL; + free(*line); } tcaps->cpos = 0; tputs(tgetstr("cr", NULL), 1, ft_putchar); @@ -119,7 +122,10 @@ char while (i < len) { if (i == tcaps->cpos) - dst[i++] = c; + { + dst[i] = c; + i++; + } else { dst[i] = str[j]; @@ -127,8 +133,8 @@ char j++; } } + free(str); dst[i] = '\0'; - ft_memdel((void*)&str); return (dst); } @@ -153,14 +159,14 @@ char i++; j++; } - free(str); + ft_memdel((void**)&str); dst[j] = '\0'; return (dst); } int16_t c_redraw_line(char *line, - uint16_t cpos, + t_caps *tcaps, t_msh *msh) { uint32_t i; @@ -168,7 +174,6 @@ int16_t int16_t ret; i = 0; - (void)cpos; tputs(tgetstr("cr", NULL), 1, ft_putchar); while (i < ft_strlen(msh->ps[0])) { @@ -177,8 +182,8 @@ int16_t } ret = ft_printf("%s", line) + ft_strlen(msh->ps[0]); len = ft_strlen(line); - if (cpos != len) - while (--len > cpos) + if (tcaps->cpos != len) + while (--len > tcaps->cpos) tputs(tgetstr("le", NULL), 1, ft_putchar); return (ret); } diff --git a/src/c_utils.h b/src/c_utils.h index e915365..62179b7 100644 --- a/src/c_utils.h +++ b/src/c_utils.h @@ -15,7 +15,7 @@ #include "s_struct.h" -int16_t c_redraw_line(char *line, uint16_t cpos, t_msh *msh); +int16_t c_redraw_line(char *line, t_caps *tcaps, t_msh *msh); char *c_delchar(char *str, uint16_t cpos); uint16_t c_get_win_size(struct winsize *ws); int32_t c_catch_tcaps(char *buf, char **line, t_caps *tcaps, t_msh *msh); |