working on args
This commit is contained in:
@@ -31,7 +31,8 @@ typedef enum e_redir
|
|||||||
_NR,
|
_NR,
|
||||||
_RED_L,
|
_RED_L,
|
||||||
_RED_R,
|
_RED_R,
|
||||||
_RED_DR
|
_RED_DR,
|
||||||
|
_RED_DL
|
||||||
} t_redir;
|
} t_redir;
|
||||||
|
|
||||||
typedef struct s_ast_n
|
typedef struct s_ast_n
|
||||||
@@ -48,9 +49,10 @@ typedef struct s_ast_n
|
|||||||
int _stdout;
|
int _stdout;
|
||||||
int _stdin;
|
int _stdin;
|
||||||
int save_std;
|
int save_std;
|
||||||
t_redir redir;
|
t_redir *inredir;
|
||||||
char *infile;
|
t_redir *outredir;
|
||||||
char *outfile;
|
char **infile;
|
||||||
|
char **outfile;
|
||||||
bool sh;
|
bool sh;
|
||||||
} t_ast_n;
|
} t_ast_n;
|
||||||
|
|
||||||
|
|||||||
@@ -68,6 +68,7 @@ char *ft_tabstr(char **tab);
|
|||||||
int is_charset(char c, char *set);
|
int is_charset(char c, char *set);
|
||||||
void free_tab(char **tab);
|
void free_tab(char **tab);
|
||||||
char **free_all(char **tab, int count);
|
char **free_all(char **tab, int count);
|
||||||
|
void add_to_tab(char ***tab, char *str);
|
||||||
|
|
||||||
void ft_put_c_fd(char c, int fd);
|
void ft_put_c_fd(char c, int fd);
|
||||||
void ft_put_s_fd(char *s, int fd);
|
void ft_put_s_fd(char *s, int fd);
|
||||||
|
|||||||
56
lib/libft/srcs/format/add_to_tab.c
Normal file
56
lib/libft/srcs/format/add_to_tab.c
Normal file
@@ -0,0 +1,56 @@
|
|||||||
|
/* ************************************************************************** */
|
||||||
|
/* */
|
||||||
|
/* ::: :::::::: */
|
||||||
|
/* add_to_tab.c :+: :+: :+: */
|
||||||
|
/* +:+ +:+ +:+ */
|
||||||
|
/* By: nalebrun <nalebrun@student.s19.be> +#+ +:+ +#+ */
|
||||||
|
/* +#+#+#+#+#+ +#+ */
|
||||||
|
/* Created: 2025/02/04 09:59:01 by nalebrun #+# #+# */
|
||||||
|
/* Updated: 2025/02/04 09:59:01 by nalebrun ### ########.fr */
|
||||||
|
/* */
|
||||||
|
/* ************************************************************************** */
|
||||||
|
|
||||||
|
#include "../../libft.h"
|
||||||
|
|
||||||
|
static void free_null_ptr(void *ptr)
|
||||||
|
{
|
||||||
|
if (ptr != NULL)
|
||||||
|
{
|
||||||
|
free(ptr);
|
||||||
|
ptr = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static char **add_space_to_tab(char **tab, int count)
|
||||||
|
{
|
||||||
|
char **new_env;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
i = 0;
|
||||||
|
new_env = malloc(sizeof(char *) * (count + 1));
|
||||||
|
if (!new_env)
|
||||||
|
return (NULL);
|
||||||
|
new_env[count] = NULL;
|
||||||
|
while (tab[i] && i < count)
|
||||||
|
{
|
||||||
|
new_env[i] = ft_strdup(tab[i]);
|
||||||
|
free_null_ptr(tab[i]);
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
free_null_ptr(tab);
|
||||||
|
return (new_env);
|
||||||
|
}
|
||||||
|
|
||||||
|
void add_to_tab(char ***tab, char *str)
|
||||||
|
{
|
||||||
|
char **tmp;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
tmp = *tab;
|
||||||
|
i = 0;
|
||||||
|
while ((*tab)[i])
|
||||||
|
i++;
|
||||||
|
*tab = add_space_to_tab(*tab, i + 1);
|
||||||
|
free(tmp);
|
||||||
|
(*tab)[i] = ft_strdup(str);
|
||||||
|
}
|
||||||
@@ -36,7 +36,7 @@ void create_and_or(t_ast_n *parrent, t_node *lst, t_node *token, t_msh *msh)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
t_redir is_redir(t_node *node)
|
t_redir get_redir(t_node *node)
|
||||||
{
|
{
|
||||||
if (!node)
|
if (!node)
|
||||||
return (_NR);
|
return (_NR);
|
||||||
@@ -76,41 +76,45 @@ char **lltotab(t_node *lst, t_node *limiter)
|
|||||||
out[count] = NULL;
|
out[count] = NULL;
|
||||||
return (out);
|
return (out);
|
||||||
}
|
}
|
||||||
|
//
|
||||||
|
// void add_redir(t_redir redir, t_redir *redir_list)
|
||||||
|
// {
|
||||||
|
// }
|
||||||
|
|
||||||
t_node *get_redir_node(t_node *head)
|
void create_redir(t_node *cpy, t_ast_n *self)
|
||||||
{
|
{
|
||||||
t_node *cpy;
|
t_redir redir;
|
||||||
|
|
||||||
cpy = head;
|
while (cpy)
|
||||||
while (cpy && !is_redir(cpy))
|
{
|
||||||
|
redir = get_redir(cpy);
|
||||||
|
if (redir == _RED_R || redir == _RED_DR)
|
||||||
|
{
|
||||||
|
// add_redir(redir, self->outredir);
|
||||||
|
add_to_tab(&self->outfile, cpy->next->val);
|
||||||
|
}
|
||||||
|
else if (redir == _RED_L || redir == _RED_DL)
|
||||||
|
{
|
||||||
|
// add_redir(redir, self->inredir);
|
||||||
|
add_to_tab(&self->infile, cpy->next->val);
|
||||||
|
}
|
||||||
cpy = cpy->next;
|
cpy = cpy->next;
|
||||||
return (cpy);
|
while (cpy && get_redir(cpy) == _NR)
|
||||||
|
cpy = cpy->next;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void create_cmd(t_ast_n *self, t_node *lst)
|
void create_cmd(t_ast_n *self, t_node *lst)
|
||||||
{
|
{
|
||||||
t_node *sec_redir_node;
|
t_node *cpy;
|
||||||
|
|
||||||
self->state = _CMD;
|
self->state = _CMD;
|
||||||
self->infile = NULL;
|
self->infile = NULL;
|
||||||
self->outfile = NULL;
|
self->outfile = NULL;
|
||||||
if (is_redir(lst) != _NR)
|
self->inredir = NULL;
|
||||||
{
|
self->outredir = NULL;
|
||||||
self->cmd = ft_strdup(lst->next->next->val);
|
cpy = lst;
|
||||||
self->args = lltotab(lst->next->next, NULL);
|
create_redir(cpy, self);
|
||||||
self->infile = ft_strdup(lst->next->val);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
self->cmd = ft_strdup(lst->val);
|
|
||||||
self->args = lltotab(lst, get_redir_node(lst->next));
|
|
||||||
}
|
|
||||||
sec_redir_node = get_redir_node(lst->next);
|
|
||||||
if (lst->next && sec_redir_node)
|
|
||||||
{
|
|
||||||
self->outfile = ft_strdup(sec_redir_node->next->val);
|
|
||||||
}
|
|
||||||
self->redir = is_redir(get_redir_node(lst));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user