/* ************************************************************************** */ /* */ /* ::: :::::::: */ /* c_utils.c :+: :+: :+: */ /* +:+ +:+ +:+ */ /* By: rbousset +#+ +:+ +#+ */ /* +#+#+#+#+#+ +#+ */ /* Created: 2020/02/14 17:19:27 by rbousset #+# #+# */ /* Updated: 2020/02/14 17:19:29 by rbousset ### ########lyon.fr */ /* */ /* ************************************************************************** */ #include #include #include #include #include #include #include "c_init.h" #include "m_prompt.h" #include "m_loop.h" #include "s_struct.h" /* ** TODO: ** MULTILIGHNE ** quotes ** C-c ** NORME ** leaks on line ??? GONE ? */ uint16_t c_get_win_size(struct winsize *ws) { if (!(ioctl(STDOUT_FILENO, TIOCGWINSZ, ws))) return (-1); if (!ws->ws_col) ws->ws_col = 80; if (!ws->ws_row) ws->ws_row = 80; return (1); } int16_t c_new_line(char *line, t_msh *msh, t_caps *tcaps) { write(1, "\n", 1); tputs(tgetstr("cr", NULL), 1, ft_putchar); c_set_term_raw(0); if (line != NULL) { m_parse_and_run_line(line, msh); line = NULL; free(line); } tcaps->cpos = 0; tputs(tgetstr("cr", NULL), 1, ft_putchar); c_set_term_raw(1); m_prompt_psx(1, msh); return (1); } char *c_insert_char(char *str, char c, t_caps *tcaps) { size_t i; size_t j; size_t len; char *dst; i = 0; j = 0; len = (ft_strlen(str) + 2); if (!(dst = (char*)malloc((len) * sizeof(char)))) return (NULL); while (i < len) { if (i == tcaps->cpos) { dst[i] = c; i++; } else { dst[i] = str[j]; i++; j++; } } ft_memdel((void**)&str); return (dst); } char *c_delchar(char *str, uint16_t cpos) { char *dst; uint16_t i; uint16_t j; j = 0; i = 0; if (!(dst = malloc((ft_strlen(str)) * sizeof(char)))) return (NULL); cpos -= 1; while (j < (ft_strlen(str) - 1)) { if (i == cpos) i++; dst[j] = str[i]; i++; j++; } ft_memdel((void**)&str); dst[j] = '\0'; return (dst); } int16_t c_redraw_line(char *line, t_caps *tcaps, t_msh *msh) { uint32_t i; uint32_t len; int16_t ret; i = 0; len = ft_strlen(line); tputs(tgetstr("cr", NULL), 1, ft_putchar); if (len >= (tcaps->ws.ws_col - ft_strlen(msh->ps[0]))) { if (len == (tcaps->ws.ws_col - ft_strlen(msh->ps[0]))) { tputs(tgetstr("sf", NULL), 1, ft_putchar); return (1); } else { tputs(tgetstr("sf", NULL), 1, ft_putchar); tputs(tgetstr("up", NULL), 1, ft_putchar); tputs(tgetstr("up", NULL), 1, ft_putchar); } } while (i < ft_strlen(msh->ps[0])) { tputs(tgetstr("nd", NULL), 1, ft_putchar); i++; } ret = ft_printf("%s", line) + ft_strlen(msh->ps[0]); if (tcaps->cpos != len) while (--len > tcaps->cpos) tputs(tgetstr("le", NULL), 1, ft_putchar); return (ret); }