diff options
| -rw-r--r-- | Makefile | 1 | ||||
| -rw-r--r-- | src/c_init.c | 167 | ||||
| -rw-r--r-- | src/c_input.c | 37 | ||||
| -rw-r--r-- | src/c_input.h | 20 | 
4 files changed, 142 insertions, 83 deletions
| @@ -26,6 +26,7 @@ SRCS_NAME		+= b_pwd  SRCS_NAME		+= b_type  SRCS_NAME		+= b_unset  SRCS_NAME		+= c_init +SRCS_NAME		+= c_input  SRCS_NAME		+= e_builtins  SRCS_NAME		+= e_externs  SRCS_NAME		+= e_externs_next diff --git a/src/c_init.c b/src/c_init.c index 5d07ed1..9dde271 100644 --- a/src/c_init.c +++ b/src/c_init.c @@ -18,6 +18,7 @@  #include <libft.h>  #include "c_init.h" +#include "c_input.h"  #include "m_prompt.h"  #include "m_loop.h"  #include "s_struct.h" @@ -26,11 +27,11 @@ static char  	*ft_strjoin_m(char *s1,  				  char *s2)  { -	size_t	i; -	size_t	j; -	char	*dst; -	size_t	size1; -	size_t	size2; +	size_t  i; +	size_t  j; +	char    *dst; +	size_t  size1; +	size_t  size2;  	i = -1;  	j = -1; @@ -48,21 +49,21 @@ static char  }  static t_caps -    *c_get_struct(int mode, t_caps *src) +	*c_get_struct(int mode, t_caps *src)  { -    static t_caps *caps; +	static t_caps *caps; -    if (mode == 1) -    { -        caps = src; -    } -    return (caps); +	if (mode == 1) +	{ +		caps = src; +	} +	return (caps);  }  static int16_t -    c_set_term_raw(uint8_t mode) +	c_set_term_raw(uint8_t mode)  { -    struct termios tios; +	struct termios tios;  	ft_memset(&tios, 0, sizeof(tios));  	tcgetattr(STDIN_FILENO, &tios); @@ -79,87 +80,87 @@ static int16_t  		tios.c_oflag |= (OPOST);  	}  	tcsetattr(STDIN_FILENO, TCSAFLUSH, &tios); -    tputs(tgetstr("cd", NULL), 1, ft_putchar); +	mode ? tputs(tgetstr("ns", NULL), 1, ft_putchar) : 0;  	return (1);  }  int16_t -    c_process_key(t_msh *msh, char *buf) +	c_process_key(t_msh *msh, char *buf)  { -    int i; -    static char *line; +	int i; +	static char *line = NULL; -    i = -1; -    if (line == NULL) -        if (!(line = ft_calloc(2, sizeof(char)))) -            return (0); -    if (ft_isprint(buf[0])) -    { -        if (*buf == 'q') -        { -            tputs(tgetstr("ve", NULL), 1, ft_putchar); -            exit(0); -        } -        else if (*buf == '\n') -            tputs(tgetstr("nl", NULL), 1, ft_putchar); -        line = ft_strjoin_m(line, buf); -        ft_printf("line [%s][%lu]", line, ft_strlen(line)); /* ft_redraw */ -    } -    else -    { -        if (strncmp(buf, tgetstr("kr", NULL), ft_strlen(tgetstr("kr", NULL))) == 0) -        { -            tputs(tgetstr("nd", NULL), 1, ft_putchar); -            return (1); -        } -        else if (buf[0] == '\n') -        { -            write(1, buf, ft_strlen(buf)); -            tputs(tgetstr("cr", NULL), 1, ft_putchar); -            m_parse_and_run_line(line, msh); -            tputs(tgetstr("cr", NULL), 1, ft_putchar); -            ft_memdel((void**)&line); -            m_prompt_psx(1, msh); -            return (1); -        } -        else if (strncmp(buf, tgetstr("kl", NULL), ft_strlen(tgetstr("kl", NULL))) == 0) -        { -            tputs(tgetstr("le", NULL), 1, ft_putchar); -            return (1); -        } -        else if (strncmp(buf, tgetstr("kb", NULL), ft_strlen(tgetstr("kb", NULL))) == 0) -        { -            tputs(tgetstr("le", NULL), 1, ft_putchar); -            tputs(tgetstr("dc", NULL), 1, ft_putchar); -            return (1); -        } -    } -    return (0); +	i = -1; +	if (line == NULL) +		if (!(line = ft_calloc(2, sizeof(char)))) +			return (0); +	if (ft_isprint(buf[0])) +	{ +		if (*buf == 'q') +		{ +			tputs(tgetstr("ve", NULL), 1, ft_putchar); +			c_set_term_raw(0); +			exit(0); +		} +		line = ft_strjoin_m(line, buf); +		c_redraw_line(line, msh); +	} +	else +	{ +		if (strncmp(buf, tgetstr("kr", NULL), ft_strlen(tgetstr("kr", NULL))) == 0) +		{ +			tputs(tgetstr("nd", NULL), 1, ft_putchar); +			return (1); +		} +		else if (buf[0] == '\n') +		{ +			write(1, buf, ft_strlen(buf)); +			tputs(tgetstr("cr", NULL), 1, ft_putchar); +			m_parse_and_run_line(line, msh); +			line = NULL; +			tputs(tgetstr("cr", NULL), 1, ft_putchar); +			m_prompt_psx(1, msh); +			return (1); +		} +		else if (strncmp(buf, tgetstr("kl", NULL), ft_strlen(tgetstr("kl", NULL))) == 0) +		{ +			tputs(tgetstr("le", NULL), 1, ft_putchar); +			return (1); +		} +		else if (strncmp(buf, tgetstr("kb", NULL), ft_strlen(tgetstr("kb", NULL))) == 0) +		{ +			tputs(tgetstr("le", NULL), 1, ft_putchar); +			tputs(tgetstr("dc", NULL), 1, ft_putchar); +			return (1); +		} +	} +	return (0);  }  int16_t c_init_tcaps(t_msh *msh)  { -    t_caps tcaps; -    char *bp; -    char *term; -    char nread[5]; -    int ret; +	t_caps tcaps; +	char *bp; +	char *term; +	char nread[5]; +	int ret; -    bp = NULL; -    term = getenv("TERM"); -    if (!tgetent(bp, term)) -        return (-1); +	bp = NULL; +	term = getenv("TERM"); +	if (!tgetent(bp, term)) +		return (-1); -    c_set_term_raw(1); -    c_get_struct(1, &tcaps); -    while (1) -    { -        ft_bzero(nread, 5); -        if (!(read(STDIN_FILENO, nread, 4))) -            return (0); +	ft_printf("my term is %s", term); +	c_set_term_raw(1); +	c_get_struct(1, &tcaps); +	while (1) +	{ +		ft_bzero(nread, 5); +		if (!(read(STDIN_FILENO, nread, 4))) +			return (0);  		tputs(tgetstr("vi", NULL), 1, ft_putchar); -        ret = c_process_key(msh, nread); +		ret = c_process_key(msh, nread);  		tputs(tgetstr("ve", NULL), 1, ft_putchar); -    } -    return (1); +	} +	return (1);  } diff --git a/src/c_input.c b/src/c_input.c new file mode 100644 index 0000000..bd963ad --- /dev/null +++ b/src/c_input.c @@ -0,0 +1,37 @@ +/* ************************************************************************** */ +/*                                                                            */ +/*                                                        :::      ::::::::   */ +/*   c_input.c                                          :+:      :+:    :+:   */ +/*                                                    +:+ +:+         +:+     */ +/*   By: rbousset <marvin@42.fr>                    +#+  +:+       +#+        */ +/*                                                +#+#+#+#+#+   +#+           */ +/*   Created: 2020/02/14 17:19:27 by rbousset          #+#    #+#             */ +/*   Updated: 2020/02/14 17:19:29 by rbousset         ###   ########lyon.fr   */ +/*                                                                            */ +/* ************************************************************************** */ + +#include <libft.h> +#include <term.h> + +#include "c_init.h" +#include "m_prompt.h" +#include "m_loop.h" +#include "s_struct.h" + + +int16_t +	c_redraw_line(char *line, t_msh *msh) +{ +	uint32_t i; +	int16_t ret; + +	i = 0; +	tputs(tgetstr("cr", 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]); +	return (ret); +} diff --git a/src/c_input.h b/src/c_input.h new file mode 100644 index 0000000..11bf671 --- /dev/null +++ b/src/c_input.h @@ -0,0 +1,20 @@ +/* ************************************************************************** */ +/*                                                                            */ +/*                                                        :::      ::::::::   */ +/*   c_input.c                                          :+:      :+:    :+:   */ +/*                                                    +:+ +:+         +:+     */ +/*   By: rbousset <marvin@42.fr>                    +#+  +:+       +#+        */ +/*                                                +#+#+#+#+#+   +#+           */ +/*   Created: 2020/02/14 17:19:27 by rbousset          #+#    #+#             */ +/*   Updated: 2020/02/14 17:19:29 by rbousset         ###   ########lyon.fr   */ +/*                                                                            */ +/* ************************************************************************** */ + +#ifndef C_INPUT_H +#define C_INPUT_H + +#include "s_struct.h" + +int16_t c_redraw_line(char *line, t_msh *msh); + +#endif | 
