diff options
Diffstat (limited to '')
-rw-r--r-- | src/ft_b_echo.c | 2 | ||||
-rw-r--r-- | src/ft_b_env.c | 2 | ||||
-rw-r--r-- | src/ft_e_lcom.c | 12 | ||||
-rw-r--r-- | src/ft_m_loop.c | 2 | ||||
-rw-r--r-- | src/ft_p_lcom.c | 15 | ||||
-rw-r--r-- | src/ft_p_line.c | 2 | ||||
-rw-r--r-- | src/ft_s_init.c | 2 | ||||
-rw-r--r-- | src/ft_s_lcom.c | 93 | ||||
-rw-r--r-- | src/ft_s_lcom.h | 4 | ||||
-rw-r--r-- | src/ft_s_struct.h | 3 |
10 files changed, 109 insertions, 28 deletions
diff --git a/src/ft_b_echo.c b/src/ft_b_echo.c index f7b83a2..d5e4a64 100644 --- a/src/ft_b_echo.c +++ b/src/ft_b_echo.c @@ -16,7 +16,7 @@ int32_t ft_b_echo(char *args[], - t_msh *msh) + t_msh *msh) { (void)msh; while (*args) diff --git a/src/ft_b_env.c b/src/ft_b_env.c index 4f26788..eb3b107 100644 --- a/src/ft_b_env.c +++ b/src/ft_b_env.c @@ -17,7 +17,7 @@ int32_t ft_b_env(char *args[], - t_msh *msh) + t_msh *msh) { char **ptr; diff --git a/src/ft_e_lcom.c b/src/ft_e_lcom.c index c592f3c..b928004 100644 --- a/src/ft_e_lcom.c +++ b/src/ft_e_lcom.c @@ -17,7 +17,7 @@ static uint8_t ft_get_builtin_id(const char com[], - t_msh *msh) + t_msh *msh) { uint8_t i; @@ -32,20 +32,22 @@ static uint8_t int32_t ft_e_lcom(t_msh *msh) { + t_lcom *ptr; uint8_t bu_id; - while (msh->lcom_head != NULL) + ptr = msh->curr; + while (ptr != NULL) { - if ((bu_id = ft_get_builtin_id(msh->lcom_head->com, msh)) + if ((bu_id = ft_get_builtin_id(ptr->com, msh)) < FT_BUILTINS_COUNT) { - msh->bu_ptr[bu_id](msh->lcom_head->args, msh); + msh->bu_ptr[bu_id](ptr->args, msh); } else { /* TODO: exec path stuff */ } - msh->lcom_head = msh->lcom_head->next; + ptr = ptr->next; } return (0); } diff --git a/src/ft_m_loop.c b/src/ft_m_loop.c index 4c22009..3a44d05 100644 --- a/src/ft_m_loop.c +++ b/src/ft_m_loop.c @@ -18,6 +18,7 @@ #include "ft_m_loop.h" #include "ft_m_prompt.h" #include "ft_p_line.h" +#include "ft_s_lcom.h" int32_t ft_m_loop(t_msh *msh) @@ -35,6 +36,7 @@ int32_t ft_p_line(line, msh); ft_memdel((void*)&line); ft_e_lcom(msh); + ft_lcom_clear(&msh->curr); /* TODO: memdel lcom - INSTALL VALGRIND */ } else diff --git a/src/ft_p_lcom.c b/src/ft_p_lcom.c index 6711b85..f928f5d 100644 --- a/src/ft_p_lcom.c +++ b/src/ft_p_lcom.c @@ -17,26 +17,23 @@ int8_t ft_p_lcom(const char line[], - const uint64_t count, - t_msh *msh) + const uint64_t count, + t_msh *msh) { uint64_t i; - char **words; + t_lcom *link; + char **words; i = 0; if (!(words = ft_split(line, ';'))) return (-1); while (i <= count) { - if (!(msh->lcom = ft_lcom_new(words[i]))) + if (!(link = ft_lcom_new(words[i]))) { return (-1); } - if (i < 1) - { - msh->lcom_head = msh->lcom; - } - msh->lcom = msh->lcom->next; + ft_lcom_add_back(&msh->curr, link); i++; } return (0); diff --git a/src/ft_p_line.c b/src/ft_p_line.c index 606408b..f299f64 100644 --- a/src/ft_p_line.c +++ b/src/ft_p_line.c @@ -19,7 +19,7 @@ void ft_p_line(char line[], - t_msh *msh) + t_msh *msh) { uint64_t i; uint64_t count; diff --git a/src/ft_s_init.c b/src/ft_s_init.c index 27075cf..63856c2 100644 --- a/src/ft_s_init.c +++ b/src/ft_s_init.c @@ -33,6 +33,6 @@ t_msh msh->envp = envp; msh->ret = 0; ft_init_buptr(msh); - msh->lcom = NULL; + msh->curr = NULL; return (msh); } diff --git a/src/ft_s_lcom.c b/src/ft_s_lcom.c index 737c6eb..8b61f69 100644 --- a/src/ft_s_lcom.c +++ b/src/ft_s_lcom.c @@ -12,24 +12,101 @@ #include <libft.h> #include <stdlib.h> +#include <stdint.h> #include "ft_s_struct.h" +static int8_t + ft_fill_lcom(char *words[], + t_lcom **lcom) +{ + int64_t i; + int64_t j; + + i = 0; + if (!((*lcom)->com = (char*)malloc((ft_strlen(words[0]) + 1) * + sizeof(char)))) + return (-1); + ft_strlcpy((*lcom)->com, words[0], ft_strlen(words[0]) + 1); + while(words[i + 1]) + i++; + if (i > 0) + { + if (!((*lcom)->args = (char**)malloc((i + 1) * sizeof(char*)))) + return (-1); + j = -1; + while (++j < i) + { + if (!((*lcom)->args[j] = + (char*)malloc((ft_strlen(words[j + 1]) + 1) * sizeof(char)))) + return (-1); + ft_strlcpy((*lcom)->args[j], words[j + 1], + ft_strlen(words[j + 1]) + 1); + } + (*lcom)->args[j] = 0; + } + return (0); +} + +t_lcom + *ft_lcom_last(t_lcom *lcom) +{ + while (lcom->next != NULL) + lcom = lcom->next; + return (lcom); +} + +void + ft_lcom_add_back(t_lcom **alcom, + t_lcom *new) +{ + t_lcom *tmp; + + if (!*alcom) + *alcom = new; + else + { + tmp = ft_lcom_last(*alcom); + tmp->next = new; + } +} + +void + ft_lcom_clear(t_lcom **lcom) +{ + t_lcom *tmp; + t_lcom *renext; + + if (!lcom) + return ; + tmp = *lcom; + while (tmp) + { + renext = tmp->next; + ft_memdel((void*)&tmp->com); + if (tmp->args) + ft_delwords(tmp->args); + ft_memdel((void*)&tmp); + tmp = renext; + } + *lcom = NULL; +} + t_lcom *ft_lcom_new(const char word[]) { - t_lcom *nlcom; + t_lcom *link; char **words; - if (!(nlcom = (t_lcom*)malloc(sizeof(t_lcom)))) - { + if (!(link = (t_lcom*)malloc(sizeof(t_lcom)))) return (NULL); - } if (!(words = ft_split(word, ' '))) + return (NULL); + if (ft_fill_lcom(words, &link) < 0) { + ft_delwords(words); return (NULL); } - nlcom->com = words[0]; - nlcom->args = words + 1; - nlcom->next = NULL; - return (nlcom); + link->next = NULL; + ft_delwords(words); + return (link); } diff --git a/src/ft_s_lcom.h b/src/ft_s_lcom.h index 14a0c39..eae0501 100644 --- a/src/ft_s_lcom.h +++ b/src/ft_s_lcom.h @@ -15,6 +15,10 @@ #include "ft_s_struct.h" +void ft_lcom_add_back(t_lcom **alcom, + t_lcom *new); +void ft_lcom_clear(t_lcom **lcom); t_lcom *ft_lcom_new(const char word[]); +t_lcom *ft_lcom_last(t_lcom *lcom); #endif diff --git a/src/ft_s_struct.h b/src/ft_s_struct.h index 34a3182..9719a6f 100644 --- a/src/ft_s_struct.h +++ b/src/ft_s_struct.h @@ -30,8 +30,7 @@ typedef struct s_msh int32_t ret; char **bu_ref; int32_t (*bu_ptr[FT_BUILTINS_COUNT])(char **, struct s_msh*); - struct s_lcom *lcom_head; - struct s_lcom *lcom; + struct s_lcom *curr; } t_msh; #endif |