summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/d_define.h1
-rw-r--r--src/e_redirs.c1
-rw-r--r--src/p_redirs.c30
3 files changed, 20 insertions, 12 deletions
diff --git a/src/d_define.h b/src/d_define.h
index fb387b3..65d4567 100644
--- a/src/d_define.h
+++ b/src/d_define.h
@@ -80,6 +80,7 @@
#define C_EQUALS 0x3d
#define C_BACKS 0x5c
#define C_PIPE 0x7c
+#define C_TILDE 0x7e
/*
** ====== FILES ======
diff --git a/src/e_redirs.c b/src/e_redirs.c
index 474e043..7416349 100644
--- a/src/e_redirs.c
+++ b/src/e_redirs.c
@@ -67,7 +67,6 @@ void e_dup_redirs(const t_com *com, t_msh *msh)
ptr = com->rdr;
while (ptr != NULL)
{
- ft_printf("PATH: [%s]; FD: [%d]; RDR: [%hhd]\n", ptr->path, ptr->fd, ptr->redir);
if (ptr->redir == -1)
{
e_redir_minus_one(ptr, msh);
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;