diff options
| author | Charles <sircharlesaze@gmail.com> | 2020-06-16 10:10:48 +0200 |
|---|---|---|
| committer | Charles <sircharlesaze@gmail.com> | 2020-06-16 10:11:58 +0200 |
| commit | 46c33fbad5e4965d2d56579e0ce6a97f310b3019 (patch) | |
| tree | 09180cccae5b8e2628dd6f36461db99ae4ddbc0d /src/lexer | |
| parent | 28ab60062e26347cb1f28dfea63dbd8090252e4d (diff) | |
| parent | 25ba3ac2ccef9ba8295c3975a1681baa033c5ee6 (diff) | |
| download | minishell-46c33fbad5e4965d2d56579e0ce6a97f310b3019.tar.gz minishell-46c33fbad5e4965d2d56579e0ce6a97f310b3019.tar.bz2 minishell-46c33fbad5e4965d2d56579e0ce6a97f310b3019.zip | |
Merge branch 'parse_cmd' into eval
Diffstat (limited to 'src/lexer')
| -rw-r--r-- | src/lexer/lexer.c | 22 | ||||
| -rw-r--r-- | src/lexer/trim.c | 64 |
2 files changed, 73 insertions, 13 deletions
diff --git a/src/lexer/lexer.c b/src/lexer/lexer.c index 1d520c7..49be432 100644 --- a/src/lexer/lexer.c +++ b/src/lexer/lexer.c @@ -84,7 +84,6 @@ t_token *lexer_lst_token_str(char *input, int i, int j) free(lst_token); return(0); } - //printf("%s-\n", lst_token->content); return (lst_token); } @@ -93,7 +92,6 @@ enum e_token_tag token_verif_stick(t_token *lst_token) int i; i = ft_strlen(lst_token->content); - if (i > 0) if (lst_token->content[i - 1] == ' ') return(lst_token->tag); @@ -109,7 +107,7 @@ enum e_token_tag token_str_or_cote(t_token *lst_token) { if(lst_token->content[i] == '\'') { - return (lst_token->tag = TAG_STR_SINGLE); + lst_token->tag = TAG_STR_SINGLE; return(token_verif_stick(lst_token)); } if(lst_token->content[i] == '"') @@ -127,7 +125,7 @@ enum e_token_tag token_str_or_cote(t_token *lst_token) return(0); } -t_token *push_token_enum_and_trim(t_token *lst_token) +t_token *push_token_enum(t_token *lst_token) { enum e_token_tag tk; @@ -137,7 +135,6 @@ t_token *push_token_enum_and_trim(t_token *lst_token) lst_token->tag = token_str_or_cote(lst_token); else lst_token->tag = tk; - //printf("%s-, %d\n",lst_token->content, lst_token->tag); return (lst_token); } @@ -154,7 +151,7 @@ static t_ftlst *create_token_list(char *input, t_ftlst **lst) j = 0; j += check_input(&input[i]); lst_token = lexer_lst_token_str(input,i,j); - lst_token = push_token_enum_and_trim(lst_token); + lst_token = push_token_enum(lst_token); new = ft_lstnew((void *) lst_token); ft_lstpush_back(lst, new); i += j; @@ -164,16 +161,15 @@ static t_ftlst *create_token_list(char *input, t_ftlst **lst) t_ftlst *lexer(char *input) { - t_ftlst **lst; - /* int i; */ + t_ftlst *lst; if (!input) return (0); - lst = malloc(sizeof(t_ftlst *) * 1); + lst = malloc(sizeof(t_ftlst ) * 1); if (!lst) return(0); - *lst = NULL; - *lst = create_token_list(input, lst); - /* i = ft_lstsize(*lst); */ - return (*lst); + lst = NULL; + lst = create_token_list(input, &lst); + lst = lexe_trim_out(lst); + return (lst); } diff --git a/src/lexer/trim.c b/src/lexer/trim.c new file mode 100644 index 0000000..ad696a4 --- /dev/null +++ b/src/lexer/trim.c @@ -0,0 +1,64 @@ + +#include "lexer.h" + +char *del_space(t_token *tk) +{ + int i; + char *s; + + i = 0; + while(tk->content[++i] != '\0') + { + if(tk->content[i] == '\\' && tk->content[i + 1] == ' ') + { + i += 2; + if (tk->content[i] == '\0') + tk->tag = tk->tag | TAG_STICK; + } + if(tk->content[i] == ' ') + break; + } + s = ft_strsubf(tk->content, 0, i); + return(s); +} + +char *del_quote(char *str) +{ + int i; + char *s; + + i = 1; + while(str[++i] != '\0') + if (str[i] == '\'' || str[i] == '"') + break; + s = ft_strsubf(str, 1, i - 1); + return (s); +} + +t_ftlst *lexe_trim_out(t_ftlst *lst) +{ + t_ftlst *first; + t_token *tk; + + first = lst; + while(lst != NULL) + { + tk = lst->data; + if (tk->tag >= TAG_STR_DOUBLE || tk->tag >= TAG_STR_SINGLE) + { + tk->content = del_quote(tk->content); + if(lst->next == NULL) + if (tk->tag & TAG_STICK) + tk->tag -= TAG_STICK; + } + else + { + tk->content = del_space(tk); + if(lst->next == NULL) + if (tk->tag & TAG_STICK) + tk->tag -= TAG_STICK; + } + lst = lst->next; + } + return (first); +} |
