diff options
author | JozanLeClerc <bousset.rudy@gmail.com> | 2020-09-20 14:51:11 +0200 |
---|---|---|
committer | JozanLeClerc <bousset.rudy@gmail.com> | 2020-09-20 14:51:11 +0200 |
commit | 613541b99bb02a4dd03d8bd9391eeab5a4c5e986 (patch) | |
tree | 83c129b139e7865cbc81d6237ace8e9e1fdb78a2 /src/s_lredir.c | |
parent | Good luck have fuck (diff) | |
download | 42-minishell-613541b99bb02a4dd03d8bd9391eeab5a4c5e986.tar.gz 42-minishell-613541b99bb02a4dd03d8bd9391eeab5a4c5e986.tar.bz2 42-minishell-613541b99bb02a4dd03d8bd9391eeab5a4c5e986.tar.xz 42-minishell-613541b99bb02a4dd03d8bd9391eeab5a4c5e986.tar.zst 42-minishell-613541b99bb02a4dd03d8bd9391eeab5a4c5e986.zip |
Redirs rework in progress
Diffstat (limited to 'src/s_lredir.c')
-rw-r--r-- | src/s_lredir.c | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/src/s_lredir.c b/src/s_lredir.c new file mode 100644 index 0000000..353149d --- /dev/null +++ b/src/s_lredir.c @@ -0,0 +1,71 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* s_lredir.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 <stdint.h> +#include <stdlib.h> +#include <limits.h> + +#include "s_struct.h" + +static t_lredir *s_lredir_last(struct s_lredir *lredir) +{ + while (lredir->next != NULL) + { + lredir = lredir->next; + } + return (lredir); +} + +void s_lredir_add_back(t_lredir **lredir, t_lredir *new) +{ + struct s_lredir *tmp; + + if (*lredir == NULL) + { + *lredir = new; + } + else + { + tmp = s_lredir_last(*lredir); + tmp->next = new; + } +} + +void s_lredir_clear(struct s_lredir **lredir) +{ + struct s_lredir *tmp; + struct s_lredir *renext; + + if (lredir == NULL) + return ; + tmp = *lredir; + while (tmp != NULL) + { + renext = tmp->next; + ft_memdel((void*)&tmp); + tmp = renext; + } + *lredir = NULL; +} + +struct s_lredir *s_lredir_new(const char path[], int32_t fd, int8_t redir) +{ + struct s_lredir *rdr; + + if ((rdr = (struct s_lredir*)malloc(sizeof(struct s_lredir))) == NULL) + return (NULL); + rdr->fd = fd; + rdr->redir = redir; + rdr->next = NULL; + ft_strlcpy(rdr->path, path, PATH_MAX); + return (rdr); +} |