diff options
Diffstat (limited to 'src/c_utils.c')
-rw-r--r-- | src/c_utils.c | 40 |
1 files changed, 32 insertions, 8 deletions
diff --git a/src/c_utils.c b/src/c_utils.c index 8433d40..09fda4f 100644 --- a/src/c_utils.c +++ b/src/c_utils.c @@ -24,15 +24,35 @@ /* ** TODO: -** cursor on char insert +** term(0) on exit +** cursor on char insert DONE ** quotes -** MAKE IT WORK ON XTERM FFS (arrows + reset term) ** leaks -** cleanup DONE -** prompt on beginning DONE -** c_set_term(0) on command DONE */ +int16_t + c_init_keys(t_caps *tcaps) +{ + if (tcaps) + { + tcaps->KL[0] = 27; + tcaps->KL[1] = 91; + tcaps->KL[2] = 68; + tcaps->KL[3] = 0; + tcaps->KR[0] = 27; + tcaps->KR[1] = 91; + tcaps->KR[2] = 67; + tcaps->KR[3] = 0; + tcaps->CL[0] = 12; + tcaps->CL[1] = 0; + tcaps->CL[2] = 0; + tcaps->CL[3] = 0; + return (1); + } + else + return (-1); +} + uint16_t c_get_win_size(struct winsize *ws) { @@ -58,7 +78,7 @@ char i = 0; j = 0; - len = ft_strlen(str) + 2; + len = (ft_strlen(str) + 2); if (!(dst = (char*)malloc((len) * sizeof(char)))) return (NULL); while (i < len) @@ -72,8 +92,7 @@ char j++; } } - tcaps->cpos++; - dst[len] = '\0'; + dst[i] = '\0'; ft_memdel((void*)&str); return (dst); } @@ -110,6 +129,7 @@ int16_t t_msh *msh) { uint32_t i; + uint32_t len; int16_t ret; i = 0; @@ -121,5 +141,9 @@ int16_t i++; } ret = ft_printf("%s", line) + ft_strlen(msh->ps[0]); + len = ft_strlen(line); + if (cpos != len) + while (--len > cpos) + tputs(tgetstr("le", NULL), 1, ft_putchar); return (ret); } |