/* ************************************************************************** */ /* */ /* ::: :::::::: */ /* words_expansions.c :+: :+: :+: */ /* +:+ +:+ +:+ */ /* By: lperrey +#+ +:+ +#+ */ /* +#+#+#+#+#+ +#+ */ /* Created: 2021/11/07 02:01:33 by lperrey #+# #+# */ /* Updated: 2021/11/13 21:27:20 by lperrey ### ########.fr */ /* */ /* ************************************************************************** */ #include "minishell.h" enum e_in_quote_state { NOT_IN = 0, IN_QUOTES = '\'', IN_DQUOTES = '\"' }; 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); char **ft_split_quotes(char const *s, char c); // Generic char *ft_strdup_quotes(const char *s); // Generic 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 *t) { void *tmp_expand; char **tmp_split; while (t) { if (t->id == T_WORD) { // 1 tmp_expand = expand_token(t->content); if (!tmp_expand) return (0); // 2 tmp_expand = rejoin_after_expand(tmp_expand); if (!tmp_expand) return (0); // 3 tmp_split = ft_split_quotes(tmp_expand, ' '); free(tmp_expand); if (!tmp_split) return (0); // 4 tmp_expand = ft_dup_2d_arr(tmp_split, (t_dup_func)ft_strdup_quotes); ft_free_2d_arr(tmp_split); tmp_split = tmp_expand; if (!tmp_split) return (0); // 5 if (!new_token_for_each_field(tmp_split, &t)) return (0); } t = t->next; } return (1); }