diff options
Diffstat (limited to '')
| -rw-r--r-- | src/c_init.c | 3 | ||||
| -rw-r--r-- | src/c_init.h | 5 | ||||
| -rw-r--r-- | src/s_init_next.c | 46 | 
3 files changed, 40 insertions, 14 deletions
| diff --git a/src/c_init.c b/src/c_init.c index 2ba73f5..5e09031 100644 --- a/src/c_init.c +++ b/src/c_init.c @@ -88,6 +88,9 @@ static short  		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)) == UP_K) || +			((*((unsigned int *)buf)) == CTRL_P)) +			return (ft_dprintf(0, "qweqwe\n"));  	else if ((*((unsigned int *)buf)) == CTRL_D &&  			line[0] == '\0')  	{ diff --git a/src/c_init.h b/src/c_init.h index f563df2..a41202d 100644 --- a/src/c_init.h +++ b/src/c_init.h @@ -18,8 +18,10 @@  # include "s_struct.h" -# define LEFT_K  0x445b1b +# define UP_K  0x415b1b +# define DOWN_K 0x425b1b  # define RIGHT_K 0x435b1b +# define LEFT_K  0x445b1b  # define HOME_K 0x485b1b  # define END_K 0x465b1b  # define DEL_K 0x7f @@ -32,6 +34,7 @@  # define CTRL_E 0x05  # define CTRL_F 0x06  # define CTRL_L 0x0c +# define CTRL_P 0x10  typedef struct		s_caps  { diff --git a/src/s_init_next.c b/src/s_init_next.c index 4521ce1..d506d9d 100644 --- a/src/s_init_next.c +++ b/src/s_init_next.c @@ -10,16 +10,17 @@  /*                                                                            */  /* ************************************************************************** */ -#include <libft.h> -#include <stdlib.h> -#include <unistd.h>  #include <dirent.h>  #include <errno.h> +#include <libft.h>  #ifdef __linux__  # include <linux/limits.h>  #else  # include <limits.h>  #endif +#include <paths.h> +#include <stdlib.h> +#include <unistd.h>  #include "b_export_next.h"  #include "f_fail.h" @@ -27,7 +28,7 @@  #include "u_vars.h"  #include "u_vars_next.h" -void	s_inc_shlvl(t_msh *msh) +void		s_inc_shlvl(t_msh *msh)  {  	char	fmt[8];  	char	tmp[255]; @@ -52,7 +53,7 @@ void	s_inc_shlvl(t_msh *msh)  	}  } -char	**s_dupenv_del(char **nenvp, unsigned long i) +char		**s_dupenv_del(char **nenvp, unsigned long i)  {  	while (i > 0)  	{ @@ -63,20 +64,37 @@ char	**s_dupenv_del(char **nenvp, unsigned long i)  	return (NULL);  } -char	**s_dupenv(char *const envp[]) +static char	s_cpy_path(char **ptr, char *nenvp[], size_t *i) +{ +	char	tmp[255]; + +	if (*ptr != NULL) +		return (0); +	if (*ptr == NULL) +	{ +		ft_sprintf(tmp, "PATH=%s", _PATH_STDPATH); +		if ((nenvp[*i] = ft_strdup(tmp)) == NULL) +			return (1); +		*(i) += 1; +	} +	return (0); +} + +char		**s_dupenv(char *const envp[])  { -	unsigned long	i; -	char			**nenvp; +	size_t	i; +	char	**nenvp; +	char	**ptr; +	ptr = (char**)envp; +	while (*ptr != NULL && ft_strncmp(*ptr, "PATH=", 5) != 0) +		ptr++;  	i = 0;  	while (envp[i] != NULL) -	{  		i++; -	} +	i += (*ptr == NULL) ? (1) : (0);  	if ((nenvp = (char**)malloc((i + 1) * sizeof(char*))) == NULL) -	{  		return (NULL); -	}  	i = 0;  	while (envp[i] != NULL)  	{ @@ -84,11 +102,13 @@ char	**s_dupenv(char *const envp[])  			return (s_dupenv_del(nenvp, i));  		i++;  	} +	if (s_cpy_path(ptr, nenvp, &i) == 1) +			return (s_dupenv_del(nenvp, i));  	nenvp[i] = NULL;  	return (nenvp);  } -void	s_set_cwd(char cwd[], t_msh *msh) +void		s_set_cwd(char cwd[], t_msh *msh)  {  	char	fmt[PATH_MAX];  	DIR		*dir; | 
