/* ************************************************************************** */ /* */ /* ::: :::::::: */ /* words_expansions.c :+: :+: :+: */ /* +:+ +:+ +:+ */ /* By: lperrey +#+ +:+ +#+ */ /* +#+#+#+#+#+ +#+ */ /* Created: 2021/11/07 02:01:33 by lperrey #+# #+# */ /* Updated: 2021/12/02 15:46:31 by hulamy ### ########.fr */ /* */ /* ************************************************************************** */ #include "minishell.h" //t_list *ft_lstnew_generic(size_t lst_sizse, size_t content_size); t_list *expand_token(char *content); char *rejoin_after_expand(t_list *expand_lst); int new_token_for_each_field(char **fields, t_token **t); // 1 - chaque bout dans un element d'une t_list // (telle quelle si non expand, ou VARIABLE de env) // 2 - strjoin() le tout // 3 - split avec un ft_strplit() modifié (ne splitant pas dans les quotes) // 4 - quotes removal, ft_strdup_quotes() le tableau split // 5 - creer un token T_WORD pour chaque *string du **split_arr // (ft_lstadd_front() sur le token original, puis set le token orignal à : // t->id = 0 ; free(t->content) ; t->content = NULL ; pour qu'il soit ignoré sur la suite du parsing) int words_expansions(t_token *token_list) { while (token_list) { if (token_list->id == T_WORD) token_expansions(&token_list); token_list = token_list->next; } return (1); } int token_expansions(t_token **t) { void *tmp; char **tmp_split; // 1 tmp = expand_token((*t)->content); if (!tmp) return (0); // 2 tmp = rejoin_after_expand(tmp); if (!tmp) return (0); // 3 tmp_split = ft_split_quotes(tmp, ' '); free(tmp); if (!tmp_split) return (0); // 4 tmp = ft_dup_2d_arr(tmp_split, (t_dup_f)ft_strdup_quotes); ft_free_2d_arr(tmp_split); tmp_split = tmp; if (!tmp_split) return (0); // 5 if (!new_token_for_each_field(tmp_split, t)) return (0); return (1); }