diff options
author | salad <fmoenne-@student.le-101.fr> | 2020-10-20 18:44:30 +0200 |
---|---|---|
committer | salad <fmoenne-@student.le-101.fr> | 2020-10-20 18:44:30 +0200 |
commit | 6238338ae0c89c9cb16e437bf80db3f4fb1cce10 (patch) | |
tree | c8f058727128f5d7ba0e47c12b35eb135ec55a53 | |
parent | norme + backslash + delchar + init --> gnl (diff) | |
download | 42-minishell-6238338ae0c89c9cb16e437bf80db3f4fb1cce10.tar.gz 42-minishell-6238338ae0c89c9cb16e437bf80db3f4fb1cce10.tar.bz2 42-minishell-6238338ae0c89c9cb16e437bf80db3f4fb1cce10.tar.xz 42-minishell-6238338ae0c89c9cb16e437bf80db3f4fb1cce10.tar.zst 42-minishell-6238338ae0c89c9cb16e437bf80db3f4fb1cce10.zip |
globul scope
-rw-r--r-- | src/c_init.c | 26 | ||||
-rw-r--r-- | src/c_init.h | 43 | ||||
-rw-r--r-- | src/c_input.c | 2 | ||||
-rw-r--r-- | src/c_input.h | 12 | ||||
-rw-r--r-- | src/c_keys.c | 24 | ||||
-rw-r--r-- | src/c_keys.h | 4 | ||||
-rw-r--r-- | src/c_utils.c | 4 | ||||
-rw-r--r-- | src/c_utils.h | 12 |
8 files changed, 59 insertions, 68 deletions
diff --git a/src/c_init.c b/src/c_init.c index 69885fc..a77c326 100644 --- a/src/c_init.c +++ b/src/c_init.c @@ -59,16 +59,20 @@ int16_t } int16_t -c_read_cap(char *buf, char *line, t_caps *tcaps, t_msh *msh) + c_read_cap(char *buf, char *line, t_caps *tcaps, t_msh *msh) { - if (((*((unsigned int *)buf)) == LEFT_K) || ((*((unsigned int *)buf)) == CTRL_B)) + if (((*((unsigned int *)buf)) == LEFT_K) || + ((*((unsigned int *)buf)) == CTRL_B)) return (c_key_left(ft_strlen(msh->ps[tcaps->psx]), tcaps)); - else if (((*((unsigned int *)buf)) == RIGHT_K) || ((*((unsigned int *)buf)) == CTRL_F)) - return (c_key_right(ft_strlen(line), ft_strlen(msh->ps[tcaps->psx]), tcaps)); + else if (((*((unsigned int *)buf)) == RIGHT_K) || + ((*((unsigned int *)buf)) == CTRL_F)) + return (c_key_right(ft_strlen(line), + ft_strlen(msh->ps[tcaps->psx]), tcaps)); else if ((*((unsigned int *)buf)) == HOME_K) return (c_home_key(tcaps)); else if ((*((unsigned int *)buf)) == END_K) - return (c_end_key(ft_strlen(line), tcaps)); + return (c_end_key(ft_strlen(line), + ft_strlen(msh->ps[tcaps->psx]), tcaps)); else if ((*((unsigned int *)buf)) == CTRL_C) return (c_ctrl_c(NULL, tcaps, msh)); else if ((*((unsigned int *)buf)) == CTRL_L) @@ -80,8 +84,8 @@ c_read_cap(char *buf, char *line, t_caps *tcaps, t_msh *msh) static char *c_process_key(char *buf, t_caps *tcaps, t_msh *msh) { - static char *line = NULL; - int i; + static char *line = NULL; + int i; i = -1; if (line == NULL) @@ -112,11 +116,11 @@ static char } int16_t -c_gnl(int32_t fd, char **line, uint8_t psx, t_msh *msh) + c_gnl(int32_t fd, char **line, uint8_t psx, t_msh *msh) { - t_caps tcaps; - char *term; - char nread[5]; + t_caps tcaps; + char *term; + char nread[5]; term = getenv("TERM"); if (!tgetent(NULL, term)) diff --git a/src/c_init.h b/src/c_init.h index 86eb89a..cb10864 100644 --- a/src/c_init.h +++ b/src/c_init.h @@ -10,13 +10,13 @@ /* */ /* ************************************************************************** */ -#ifndef U_INIT_H -#define U_INIT_H +#ifndef C_INIT_H +# define C_INIT_H -#include <termios.h> -#include <sys/ioctl.h> +# include <termios.h> +# include <sys/ioctl.h> -#include "s_struct.h" +# include "s_struct.h" # define LEFT_K 0x445b1b # define RIGHT_K 0x435b1b @@ -30,30 +30,17 @@ # define CTRL_C 0x03 # define CTRL_L 0x0c - -typedef struct s_caps +typedef struct s_caps { - struct termios tios; - struct winsize ws; - uint32_t cpos; /*cursor position (column)*/ - uint32_t lpos; /*cursor position (line)*/ - uint32_t nlines; /*cursor position (line)*/ - uint8_t psx; /*cursor position (line)*/ -} t_caps; + struct termios tios; + struct winsize ws; + uint32_t cpos; + uint32_t lpos; + uint32_t nlines; + uint8_t psx; +} t_caps; -int16_t c_gnl(int32_t fd, char **line, uint8_t psx, t_msh *msh); -int16_t c_set_term_raw(uint8_t mode); +int16_t c_gnl(int32_t fd, char **line, uint8_t psx, t_msh *msh); +int16_t c_set_term_raw(uint8_t mode); #endif - -/* cm_str; cursor mobility*/ -/* nl; newline, returned by tgoto()*/ -/* ks; indicate that keys transmit from now on*/ -/* ke; indicate that keys transmit from now on*/ -/* pc; padding char --> do not touch (default 0)*/ -/* bc; left one char*/ -/* le; left one char*/ -/* up; up one line*/ -/* DO; down one line*/ -/* nd; right one char*/ -/* cl; line clear*/ diff --git a/src/c_input.c b/src/c_input.c index bbc6f5a..e1dce63 100644 --- a/src/c_input.c +++ b/src/c_input.c @@ -51,7 +51,7 @@ uint16_t } uint32_t -c_get_line_num(char *line, uint32_t cpos, uint32_t plen, t_caps *tcaps) + c_get_line_num(char *line, uint32_t cpos, uint32_t plen, t_caps *tcaps) { uint32_t it; uint32_t line_num; diff --git a/src/c_input.h b/src/c_input.h index a586e2f..541b712 100644 --- a/src/c_input.h +++ b/src/c_input.h @@ -11,12 +11,12 @@ /* ************************************************************************** */ #ifndef C_INPUT_H -#define C_INPUT_H +# define C_INPUT_H -int16_t c_back_slash(char **line, uint32_t plen, t_caps *tcaps); -int16_t c_ctrl_c(char *line, t_caps *tcaps, t_msh *msh); -uint32_t c_get_line_num(char *line, uint32_t cpos, uint32_t plen, t_caps *tcaps); -int16_t c_init_line(uint8_t psx, t_caps *tcaps); -uint16_t c_get_win_size(struct winsize *ws); +int16_t c_back_slash(char **line, uint32_t plen, t_caps *tcaps); +int16_t c_ctrl_c(char *line, t_caps *tcaps, t_msh *msh); +uint32_ c_get_line_num(char *line, uint32_t cpos, uint32_t plen, t_caps *tcaps); +int16_t c_init_line(uint8_t psx, t_caps *tcaps); +uint16_t c_get_win_size(struct winsize *ws); #endif diff --git a/src/c_keys.c b/src/c_keys.c index cd3e6f1..78b3d8f 100644 --- a/src/c_keys.c +++ b/src/c_keys.c @@ -29,8 +29,8 @@ int16_t int16_t c_home_key(t_caps *tcaps) { - int16_t i; - int16_t j; + uint32_t i; + int16_t j; i = tcaps->cpos; j = tcaps->lpos; @@ -40,7 +40,7 @@ int16_t while (--j > 0) tputs(tgetstr("up", NULL), 1, ft_putchar); tputs(tgetstr("cr", NULL), 1, ft_putchar); - while ((uint32_t)++i <= 13) + while (++i <= 13) tputs(tgetstr("nd", NULL), 1, ft_putchar); } else @@ -54,24 +54,24 @@ int16_t } int16_t - c_end_key(uint16_t size, t_caps *tcaps) + c_end_key(uint16_t size, uint32_t plen, t_caps *tcaps) { uint16_t i; uint16_t j; i = tcaps->cpos; j = tcaps->lpos; - if (tcaps->cpos < size && j < tcaps->nlines) + if ((tcaps->cpos < size) && (j < tcaps->nlines)) { i = 0; - while (j < (tcaps->nlines)) + while (j < tcaps->nlines) { tputs(tgetstr("do", NULL), 1, ft_putchar); i += tcaps->ws.ws_col; j++; } tputs(tgetstr("cr", NULL), 1, ft_putchar); - while (i++ < (size + 13)) + while (i++ < (size + plen)) tputs(tgetstr("nd", NULL), 1, ft_putchar); } else @@ -85,8 +85,8 @@ int16_t int16_t c_key_right(uint32_t len, uint32_t plen, t_caps *tcaps) { - if ((((tcaps->cpos + plen + 1) % (tcaps->ws.ws_col)) == 0) - && tcaps->cpos < len) + if ((((tcaps->cpos + plen + 1) % (tcaps->ws.ws_col)) == 0) && + tcaps->cpos < len) { tputs(tgetstr("do", NULL), 1, ft_putchar); tputs(tgetstr("cr", NULL), 1, ft_putchar); @@ -107,11 +107,11 @@ int16_t int32_t pos; pos = -1; - if (((tcaps->cpos + plen) % (tcaps->ws.ws_col)) == 0 - && tcaps->cpos >= 1) + if (((tcaps->cpos + plen) % tcaps->ws.ws_col) == 0 && + tcaps->cpos >= 1) { tputs(tgetstr("up", NULL), 1, ft_putchar); - while(++pos <= (tcaps->ws.ws_col)) + while (++pos <= tcaps->ws.ws_col) tputs(tgetstr("nd", NULL), 1, ft_putchar); tcaps->cpos--; tcaps->lpos--; diff --git a/src/c_keys.h b/src/c_keys.h index 250b297..6a4924d 100644 --- a/src/c_keys.h +++ b/src/c_keys.h @@ -11,12 +11,12 @@ /* ************************************************************************** */ #ifndef C_KEYS_H -#define C_KEYS_H +# define C_KEYS_H int16_t c_key_right(uint32_t len, uint32_t plen, t_caps *tcaps); int16_t c_key_left(uint32_t plen, t_caps *tcaps); int16_t c_home_key(t_caps *tcaps); -int16_t c_end_key(uint16_t size, t_caps *tcaps); +int16_t c_end_key(uint16_t size, uint32_t plen, t_caps *tcaps); int16_t c_ctrl_l(char *line, t_caps *tcaps, t_msh *msh); #endif diff --git a/src/c_utils.c b/src/c_utils.c index 3c21bff..de4e8d1 100644 --- a/src/c_utils.c +++ b/src/c_utils.c @@ -151,6 +151,6 @@ int16_t 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) : - ft_strlen(line)); + c_redraw_next(ft_strlen(msh->ps[tcaps->psx]), ft_strlen(line), tcaps) : + ft_strlen(line)); } diff --git a/src/c_utils.h b/src/c_utils.h index 6aebca8..0cea972 100644 --- a/src/c_utils.h +++ b/src/c_utils.h @@ -11,13 +11,13 @@ /* ************************************************************************** */ #ifndef C_UTILS_H -#define C_UTILS_H +# define C_UTILS_H -#include "s_struct.h" +# include "s_struct.h" -char *c_new_line(char *line, t_caps *tcaps); -char *c_insert_char(char *str, char c, t_caps *tcaps); -char *c_delchar(char *str, uint16_t cpos); -int16_t c_redraw_line(char *line, t_caps *tcaps, t_msh *msh); +char *c_new_line(char *line, t_caps *tcaps); +char *c_insert_char(char *str, char c, t_caps *tcaps); +char *c_delchar(char *str, uint16_t cpos); +int16_t c_redraw_line(char *line, t_caps *tcaps, t_msh *msh); #endif |