diff options
Diffstat (limited to '')
-rw-r--r-- | src/c_init.c | 50 | ||||
-rw-r--r-- | src/c_init.h | 1 | ||||
-rw-r--r-- | src/c_input.c | 3 | ||||
-rw-r--r-- | src/c_input.h | 8 | ||||
-rw-r--r-- | src/c_keys.c | 2 | ||||
-rw-r--r-- | src/c_utils.c | 15 | ||||
-rw-r--r-- | src/m_loop.c | 6 | ||||
-rw-r--r-- | src/m_prompt.c | 32 | ||||
-rw-r--r-- | src/m_prompt.h | 3 |
9 files changed, 59 insertions, 61 deletions
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 <stdlib.h> #include <libft.h> #include <signal.h> +#include <string.h> #include <term.h> #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); diff --git a/src/c_init.h b/src/c_init.h index db7d777..ac380dd 100644 --- a/src/c_init.h +++ b/src/c_init.h @@ -41,6 +41,7 @@ typedef struct s_caps unsigned int lpos; unsigned int nlines; unsigned short psx; + unsigned short plen; } t_caps; short c_gnl(int fd, char **line, char psx, t_msh *msh); diff --git a/src/c_input.c b/src/c_input.c index 24e45e3..7a23b90 100644 --- a/src/c_input.c +++ b/src/c_input.c @@ -58,7 +58,8 @@ unsigned short } unsigned int - c_get_line_num(char *line, unsigned int cpos, unsigned int plen, t_caps *tcaps) + c_get_line_num(char *line, unsigned int cpos, + unsigned int plen, t_caps *tcaps) { unsigned int it; unsigned int line_num; diff --git a/src/c_input.h b/src/c_input.h index 01aaa15..7ba697f 100644 --- a/src/c_input.h +++ b/src/c_input.h @@ -13,11 +13,11 @@ #ifndef C_INPUT_H # define C_INPUT_H -short c_back_slash(char **line, unsigned int plen, t_caps *tcaps); -short c_ctrl_c(char *line, t_caps *tcaps, t_msh *msh); +short c_back_slash(char **line, unsigned int plen, t_caps *tcaps); +short c_ctrl_c(char *line, t_caps *tcaps, t_msh *msh); unsigned int c_get_line_num(char *line, unsigned int cpos, unsigned int plen, - t_caps *tcaps); -short c_init_line(char psx, t_caps *tcaps); + t_caps *tcaps); +short c_init_line(char psx, t_caps *tcaps); unsigned short c_get_win_size(struct winsize *ws); #endif diff --git a/src/c_keys.c b/src/c_keys.c index 593c6d4..6d472c4 100644 --- a/src/c_keys.c +++ b/src/c_keys.c @@ -30,7 +30,7 @@ short c_home_key(unsigned int plen, t_caps *tcaps) { unsigned int i; - short j; + short j; i = tcaps->cpos; j = tcaps->lpos; diff --git a/src/c_utils.c b/src/c_utils.c index 3198dff..a25a35a 100644 --- a/src/c_utils.c +++ b/src/c_utils.c @@ -24,8 +24,8 @@ char *c_new_line(char *line, t_caps *tcaps) { - char *ret; - size_t i; + char *ret; + size_t i; i = tcaps->lpos; ret = NULL; @@ -50,7 +50,7 @@ char char *c_insert_char(char *str, char c, t_caps *tcaps) { - int i; + int i; size_t j; size_t len; char *dst; @@ -77,9 +77,9 @@ char char *c_delchar(char *str, unsigned short cpos) { - char *dst; unsigned short i; unsigned short j; + char *dst; j = 0; i = 0; @@ -135,8 +135,9 @@ short unsigned int i; unsigned int j; + (void)msh; tcaps->nlines = c_get_line_num(line, tcaps->cpos, - ft_strlen(msh->ps[tcaps->psx]), tcaps); + tcaps->plen, tcaps); i = 0; j = tcaps->lpos; tputs(tgetstr("cr", NULL), 1, ft_putchar); @@ -146,10 +147,10 @@ short tputs(tgetstr("up", NULL), 1, ft_putchar); tputs(tgetstr("up", NULL), 1, ft_putchar); } - while (i++ < ft_strlen(msh->ps[tcaps->psx])) + while (i++ < tcaps->plen) tputs(tgetstr("nd", NULL), 1, ft_putchar); ft_printf("%s", line); return ((tcaps->cpos != ft_strlen(line)) ? - c_redraw_next(ft_strlen(msh->ps[tcaps->psx]), ft_strlen(line), tcaps) : + c_redraw_next(tcaps->plen, ft_strlen(line), tcaps) : ft_strlen(line)); } diff --git a/src/m_loop.c b/src/m_loop.c index 83caf6a..03ce8e2 100644 --- a/src/m_loop.c +++ b/src/m_loop.c @@ -138,10 +138,8 @@ unsigned char m_loop(int fd, t_msh *msh) msh->curr_hist_ptr = hist; while (gnl > 0) { - if (fd == STDIN_FILENO) - gnl = c_gnl(fd, &line, 1, msh); - else - gnl = get_next_line(fd, &line); + gnl = (fd == STDIN_FILENO) ? c_gnl(fd, &line, 1, msh) : + get_next_line(fd, &line); m_delete_comments(line); if (line[0] != C_NUL) { diff --git a/src/m_prompt.c b/src/m_prompt.c index e36a07e..0fbd9f2 100644 --- a/src/m_prompt.c +++ b/src/m_prompt.c @@ -25,7 +25,7 @@ #include "s_struct.h" #include "u_vars.h" -static void m_subst_prompt_rice(char var[], t_msh *msh) +static void m_subst_prompt_rice(char var[], t_msh *msh) { size_t i; @@ -43,7 +43,7 @@ static void m_subst_prompt_rice(char var[], t_msh *msh) } } -static void m_update_psx(unsigned char x, t_msh *msh) +static void m_update_psx(unsigned char x, t_msh *msh) { char var[ARG_MAX]; char psx[5]; @@ -59,7 +59,33 @@ static void m_update_psx(unsigned char x, t_msh *msh) ft_strlcpy(msh->ps[x - 1], var, 255); } -void m_prompt_psx(unsigned char x, t_msh *msh) +unsigned int m_plen(char *prompt) +{ + unsigned int i; + unsigned int size; + + i = 0; + size = 0; + while (prompt[i] != '\0') + { + if (prompt[i] == 27) + { + while (prompt[i] != 'm' && prompt[i] != '\0') + i++; + } + if (ft_isalnum(prompt[i]) || + ft_ischarset("<>", prompt[i])) + { + size++; + i++; + } + else + i++; + } + return (size); +} + +void m_prompt_psx(unsigned char x, t_msh *msh) { m_update_psx(x, msh); ft_dprintf(STDERR_FILENO, "%s", msh->ps[x - 1]); diff --git a/src/m_prompt.h b/src/m_prompt.h index 3170ecc..59f627f 100644 --- a/src/m_prompt.h +++ b/src/m_prompt.h @@ -15,6 +15,7 @@ # include "s_struct.h" -void m_prompt_psx(unsigned char x, t_msh *msh); +unsigned int m_plen(char *prompt); +void m_prompt_psx(unsigned char x, t_msh *msh); #endif |