From b18fbce9a7e33f7e54949ae8de32fd7fc42e6ad1 Mon Sep 17 00:00:00 2001 From: salad Date: Tue, 3 Nov 2020 00:03:48 +0100 Subject: this is it \(2009\) \: a Micheal Jackson Biopic --- src/c_init.c | 50 ++++++++++---------------------------------------- 1 file changed, 10 insertions(+), 40 deletions(-) (limited to 'src/c_init.c') diff --git a/src/c_init.c b/src/c_init.c index 53af0a3..1023ced 100644 --- a/src/c_init.c +++ b/src/c_init.c @@ -14,6 +14,7 @@ #include #include #include +#include #include #include "c_init.h" @@ -23,30 +24,6 @@ #include "s_struct.h" #include "m_prompt.h" -unsigned int - c_plen(char *prompt) -{ - unsigned int i; - unsigned int size; - - i = 0; - size = 0; - while (prompt[i] != '\0') - { - if (ft_isalpha(prompt[i])) - { - i++; - size++; - } - else - { - - i++; - } - } - return (size); -} - short c_set_term_raw(char mode) { @@ -76,7 +53,7 @@ static void { *line = c_insert_char(*line, buf[0], tcaps); tcaps->cpos++; - if ((((tcaps->cpos) + ft_strlen(msh->ps[tcaps->psx])) % + if ((((tcaps->cpos) + tcaps->plen) % tcaps->ws.ws_col) == 0) { write(1, "\n\r", 2); @@ -88,21 +65,18 @@ static void static short c_read_cap(char *buf, char *line, t_caps *tcaps, t_msh *msh) { - unsigned int plen; - - plen = ft_strlen(msh->ps[tcaps->psx]); if (((*((unsigned int *)buf)) == LEFT_K) || ((*((unsigned int *)buf)) == CTRL_B)) - return (c_key_left(plen, tcaps)); + return (c_key_left(tcaps->plen, tcaps)); else if (((*((unsigned int *)buf)) == RIGHT_K) || ((*((unsigned int *)buf)) == CTRL_F)) - return (c_key_right(ft_strlen(line), plen, tcaps)); + return (c_key_right(ft_strlen(line), tcaps->plen, tcaps)); else if (((*((unsigned int *)buf)) == HOME_K) || ((*((unsigned int *)buf)) == CTRL_A)) - return (c_home_key(plen, tcaps)); + return (c_home_key(tcaps->plen, tcaps)); else if (((*((unsigned int *)buf)) == END_K) || ((*((unsigned int *)buf)) == CTRL_E)) - return (c_end_key(ft_strlen(line), plen, tcaps)); + return (c_end_key(ft_strlen(line), tcaps->plen, tcaps)); else if ((*((unsigned int *)buf)) == CTRL_L) return (c_ctrl_l(line, tcaps, msh)); else if ((*((unsigned int *)buf)) == CTRL_C) @@ -128,8 +102,8 @@ static char c_add_char(&line, buf, tcaps, msh); else if ((*((unsigned int *)buf)) == DEL_K) { - c_back_slash(&line, ft_strlen(msh->ps[tcaps->psx]), tcaps); - if ((((tcaps->cpos) + ft_strlen(msh->ps[tcaps->psx])) % + c_back_slash(&line, tcaps->plen, tcaps); + if ((((tcaps->cpos) + tcaps->plen) % tcaps->ws.ws_col) == 0) { return (NULL); @@ -152,17 +126,13 @@ short c_init_line(psx, &tcaps); tputs(tgetstr("cr", NULL), 1, ft_putchar); m_prompt_psx(psx, msh); - ft_printf("%u", c_plen(msh->ps[0])); ft_bzero(nread, 5); + tcaps.plen = m_plen(msh->ps[psx - 1]); + tcaps.plen += (psx != 1); if (!(c_get_win_size(&tcaps.ws))) return (-1); while (!(ft_strchr(nread, '\n'))) { - if (msh->ret == 130) - { - *line = ft_strdup("\0"); - return (1); - } ft_bzero(nread, 5); if (!(read(fd, nread, 4))) return (0); -- cgit v1.2.3