From e29c1e07a7badb655145d04ca8f9a468b796b67c Mon Sep 17 00:00:00 2001 From: JozanLeClerc Date: Sat, 26 Sep 2020 19:37:37 +0200 Subject: In progress --- src/p_redirs.c | 30 +++++++++++++++++++----------- 1 file changed, 19 insertions(+), 11 deletions(-) (limited to 'src/p_redirs.c') diff --git a/src/p_redirs.c b/src/p_redirs.c index cf4cf1d..d83ebfd 100644 --- a/src/p_redirs.c +++ b/src/p_redirs.c @@ -22,6 +22,7 @@ #include "s_lredir.h" #include "u_utils.h" #include "u_parse.h" +#include "u_vars.h" static void p_append_redir(const char path[], int32_t fd, @@ -44,25 +45,32 @@ static size_t p_get_path(char path[], const char word[], int8_t redir) { + char home[PATH_MAX]; size_t pos[2]; - size_t end; + size_t hlen; + size_t len; - pos[0] = 0; - pos[1] = 0; + hlen = 0; redir = (redir < 0) ? (-redir) : (redir); ptr += redir; while (*ptr != C_NUL && ft_iswhitespace(*ptr) == TRUE) ptr++; + if (*ptr == C_TILDE && u_get_var_value(home, "$HOME", PATH_MAX, msh) == 0) + { + ft_strlcpy(path, home, PATH_MAX); + hlen = ft_strlen(home); + 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); + len = (pos[1] - pos[0]); + len = ((hlen + len + 1) > PATH_MAX) ? (PATH_MAX - 1) : (len); + ft_strlcpy(path + hlen, word + pos[0], len + 1); + ft_printf("%s\n", path); return (pos[1]); } @@ -91,10 +99,10 @@ static int32_t p_get_fd(const char word[], char *ptr) static int8_t p_get_redir(char word[], char *ptr, t_com *com) { - char path[PATH_MAX]; - size_t pos[2]; - int32_t fd; - int8_t redir; + char path[PATH_MAX]; + size_t pos[2]; + int32_t fd; + int8_t redir; pos[0] = 0; pos[1] = 0; -- cgit v1.2.3