diff options
Diffstat (limited to 'src/p_lblock.c')
-rw-r--r-- | src/p_lblock.c | 63 |
1 files changed, 42 insertions, 21 deletions
diff --git a/src/p_lblock.c b/src/p_lblock.c index a9b7144..b0a5c6a 100644 --- a/src/p_lblock.c +++ b/src/p_lblock.c @@ -24,43 +24,64 @@ #include "s_lpipes.h" #include "s_struct.h" -int8_t p_line_block(const char line[], t_msh *msh) +static uint8_t p_get_nextif(char *words[], size_t i) { - /* TODO: norme */ - uint64_t i; - t_line_block *link; - char **words; - char *ptr; uint8_t nextif; - t_bool next; - i = 0; nextif = 0; - if ((words = p_split_line((char*)line)) == NULL) - return (-1); + if (words[i][ft_strlen(words[i]) - 1] == '0') + nextif = 0; + else if (words[i][ft_strlen(words[i]) - 1] == '1') + nextif = 1; + else + nextif = 2; + words[i][ft_strlen(words[i]) - 1] = '\0'; + return (nextif); +} + +static int8_t p_loop(char *words[], t_msh *msh) +{ + t_line_block *link; + size_t i; + uint8_t nextif; + + i = 0; while (words[i] != NULL) { - if (words[i][ft_strlen(words[i]) - 1] == '0') - nextif = 0; - else if (words[i][ft_strlen(words[i]) - 1] == '1') - nextif = 1; - else - nextif = 2; - words[i][ft_strlen(words[i]) - 1] = '\0'; - next = FALSE; - if ((ptr = ft_strchr(words[i], '|')) != NULL) + nextif = p_get_nextif(words, i); + if (ft_strchr(words[i], '|') != NULL) { if ((link = s_line_new(NULL, 0)) == NULL) return (-1); if ((s_split_pipes(words[i], msh)) == NULL) return (-1); - next = TRUE; + s_line_add_back(&msh->curr, link); + i++; + continue ; } - if (next == FALSE && (link = s_line_new(words[i], nextif)) == NULL) + if ((link = s_line_new(words[i], nextif)) == NULL) return (-1); s_line_add_back(&msh->curr, link); i++; } + return (0); +} + +/* +** TOOD: ft_strchr('|'): danger /!\ rewrite this shit +*/ + +int8_t p_line_block(const char line[], t_msh *msh) +{ + char **words; + + if ((words = p_split_line((char*)line)) == NULL) + return (-1); + if (p_loop(words, msh) != 0) + { + ft_delwords(words); + return (-1); + } ft_delwords(words); return (0); } |