diff options
| author | JozanLeClerc <bousset.rudy@gmail.com> | 2020-09-24 17:48:44 +0200 | 
|---|---|---|
| committer | JozanLeClerc <bousset.rudy@gmail.com> | 2020-09-24 17:48:44 +0200 | 
| commit | 9fcd3815ffe43707162143664af601649988a69a (patch) | |
| tree | 9963bcbba3f8f736d2f3d2dd199b3d4b1ea9f850 /src | |
| parent | Fixed $n stuff (diff) | |
| download | 42-minishell-9fcd3815ffe43707162143664af601649988a69a.tar.gz 42-minishell-9fcd3815ffe43707162143664af601649988a69a.tar.bz2 42-minishell-9fcd3815ffe43707162143664af601649988a69a.tar.xz 42-minishell-9fcd3815ffe43707162143664af601649988a69a.tar.zst 42-minishell-9fcd3815ffe43707162143664af601649988a69a.zip | |
In progress
Diffstat (limited to '')
| -rw-r--r-- | src/p_redirs.c | 51 | 
1 files changed, 44 insertions, 7 deletions
| diff --git a/src/p_redirs.c b/src/p_redirs.c index 2c9faa3..3f9e866 100644 --- a/src/p_redirs.c +++ b/src/p_redirs.c @@ -18,9 +18,45 @@  #include "d_define.h"  #include "s_lredir.h"  #include "s_struct.h" +#include "u_utils.h"  #include "u_parse.h" -static int32_t	p_get_fd(char word[], char *ptr) +static void		p_append_redir(const char path[], +							int32_t fd, +							int8_t redir, +							t_com *com) +{ +	struct s_lredir	*rdr; +} + +static size_t	p_get_path(char path[], +						char *ptr, +						const char word[], +						int8_t redir) +{ +	size_t	pos[2]; +	size_t	end; + +	pos[0] = 0; +	pos[1] = 0; +	redir = (redir < 0) ? (-redir) : (redir); +	ptr += redir; +	while (*ptr != C_NUL && ft_iswhitespace(*ptr) == TRUE) +		ptr++; +	pos[0] = (ptr - word); +	while (*ptr != C_NUL && +		ft_iswhitespace(*ptr) == FALSE && +		u_is_not_escaped(word, ptr) == TRUE) +		ptr++; +	pos[1] = (ptr - word); +	end = pos[1]; +	while (pos[1] - pos[0] > PATH_MAX) +		end--; +	ft_strlcpy(path, word + pos[0], end); +	return (pos[1]); +} + +static int32_t	p_get_fd(const char word[], char *ptr)  {  	char	digit[255];  	char	*tmp; @@ -45,12 +81,13 @@ static int32_t	p_get_fd(char word[], char *ptr)  static int8_t	p_get_redir(char word[], char *ptr, t_com *com)  { -	struct s_lredir	*rdr; -	/* char			path[PATH_MAX]; */ +	char			path[PATH_MAX];  	size_t			pos[2];  	int32_t			fd;  	int8_t			redir; +	pos[0] = 0; +	pos[1] = 0;  	if ((fd = p_get_fd(word, ptr)) < 0)  		fd = 0;  	redir = (*ptr == '>') ? (1) : (-1); @@ -60,10 +97,10 @@ static int8_t	p_get_redir(char word[], char *ptr, t_com *com)  		pos[0] = (ptr - word);  	else  		pos[0] = (ptr - word) - ft_intlen(fd); -	/* p_get_path(path, ptr, word); */ -	/* ft_printf("fd: %d   redir: %hhd  path: [%s]\n", fd, redir, path); */ -	(void)com; -	(void)rdr; +	pos[1] = p_get_path(path, ptr, word, redir); +	(void)ft_memmove(word + pos[0], +		word + pos[1], (ft_strlen(word + pos[1]) + 1) * sizeof(char)); +	p_append_redir(path, fd, redir, com);  	return (0);  } | 
