diff options
author | JozanLeClerc <bousset.rudy@gmail.com> | 2020-04-20 19:21:23 +0200 |
---|---|---|
committer | JozanLeClerc <bousset.rudy@gmail.com> | 2020-04-20 19:21:23 +0200 |
commit | 0daacec366aab889b2b24d7fc6edebe1370d7e28 (patch) | |
tree | b16cf4d5c03751838896acee6c2d6129f3372b3b | |
parent | Continuing (diff) | |
download | 42-minishell-0daacec366aab889b2b24d7fc6edebe1370d7e28.tar.gz 42-minishell-0daacec366aab889b2b24d7fc6edebe1370d7e28.tar.bz2 42-minishell-0daacec366aab889b2b24d7fc6edebe1370d7e28.tar.xz 42-minishell-0daacec366aab889b2b24d7fc6edebe1370d7e28.tar.zst 42-minishell-0daacec366aab889b2b24d7fc6edebe1370d7e28.zip |
Linked list not working but ok
-rw-r--r-- | libft/Makefile | 1 | ||||
-rw-r--r-- | libft/inc/libft.h | 1 | ||||
-rw-r--r-- | libft/src/ft_delwords.c | 28 | ||||
-rw-r--r-- | src/ft_e_lcom.c | 52 | ||||
-rw-r--r-- | src/ft_e_lcom.h | 22 | ||||
-rw-r--r-- | src/ft_m_funptr.c | 1 | ||||
-rw-r--r-- | src/ft_m_loop.c | 4 | ||||
-rw-r--r-- | src/ft_p_lcom.c | 3 | ||||
-rw-r--r-- | src/ft_p_lcom.h | 23 | ||||
-rw-r--r-- | src/ft_p_line.c | 1 | ||||
-rw-r--r-- | src/ft_s_destroy.c | 2 | ||||
-rw-r--r-- | src/ft_s_init.c | 2 | ||||
-rw-r--r-- | src/ft_s_lcom.c | 20 | ||||
-rw-r--r-- | src/ft_s_lcom.h | 4 | ||||
-rw-r--r-- | src/ft_s_struct.h | 2 |
15 files changed, 150 insertions, 16 deletions
diff --git a/libft/Makefile b/libft/Makefile index ec87186..398e29b 100644 --- a/libft/Makefile +++ b/libft/Makefile @@ -81,6 +81,7 @@ SRCS_NAME += ft_uintlen.c SRCS_NAME += ft_uintlen_base.c SRCS_NAME += ft_nstr.c SRCS_NAME += ft_memdel.c +SRCS_NAME += ft_delwords.c SRCS_NAME += ft_kernel_panic.c SRCS_NAME += get_next_line.c SRCS_NAME += get_next_line_utils.c diff --git a/libft/inc/libft.h b/libft/inc/libft.h index 843e97c..f85f4b3 100644 --- a/libft/inc/libft.h +++ b/libft/inc/libft.h @@ -75,6 +75,7 @@ void ft_kernel_panic(void); void ft_putnbr(long nb); void ft_putnbr_base(long nb, char *base); void ft_memdel(void **ptr); +void ft_delwords(char **words); void *ft_memset(void *b, int c, size_t len); void *ft_memcpy(void *dst, const void *src, size_t n); void *ft_memccpy(void *dst, const void *src, diff --git a/libft/src/ft_delwords.c b/libft/src/ft_delwords.c new file mode 100644 index 0000000..79c671d --- /dev/null +++ b/libft/src/ft_delwords.c @@ -0,0 +1,28 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_delwords.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rbousset <marvin@42.fr> +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/02/14 17:19:27 by rbousset #+# #+# */ +/* Updated: 2020/02/14 17:19:29 by rbousset ### ########lyon.fr */ +/* */ +/* ************************************************************************** */ + +#include <libft.h> +#include <stddef.h> + +void + ft_delwords(char **words) +{ + size_t i; + + i = 0; + while (words[i]) + { + ft_memdel((void*)&words[i]); + i++; + } + ft_memdel((void*)&words); +} diff --git a/src/ft_e_lcom.c b/src/ft_e_lcom.c new file mode 100644 index 0000000..5e37084 --- /dev/null +++ b/src/ft_e_lcom.c @@ -0,0 +1,52 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_e_lcom.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rbousset <marvin@42.fr> +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/02/14 17:19:27 by rbousset #+# #+# */ +/* Updated: 2020/02/14 17:19:29 by rbousset ### ########lyon.fr */ +/* */ +/* ************************************************************************** */ + +#include <libft.h> +#include <stdint.h> +#include <stdlib.h> +#include "ft_s_struct.h" + +static uint8_t + ft_get_builtin_id(const char com[], + t_msh *msh) +{ + uint8_t i; + + i = 0; + while (ft_strncmp(com, msh->bu_ref[i], 7) != 0) + { + i++; + } + return (i); +} + +int32_t + ft_e_lcom(t_lcom *lcom, + t_msh *msh) +{ + uint8_t bu_id; + + while (lcom != NULL) + { + ft_printf("qwe\n"); + if ((bu_id = ft_get_builtin_id(lcom->com, msh)) < FT_BUILTINS_COUNT) + { + msh->bu_ptr[bu_id](msh); + } + else + { + /* TODO: exec path stuff */ + } + lcom = lcom->next; + } + return (0); +} diff --git a/src/ft_e_lcom.h b/src/ft_e_lcom.h new file mode 100644 index 0000000..a273388 --- /dev/null +++ b/src/ft_e_lcom.h @@ -0,0 +1,22 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_e_lcom.h :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rbousset <marvin@42.fr> +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/02/14 17:19:27 by rbousset #+# #+# */ +/* Updated: 2020/02/14 17:19:29 by rbousset ### ########lyon.fr */ +/* */ +/* ************************************************************************** */ + +#ifndef FT_E_LCOM_H +#define FT_E_LCOM_H + +#include <stdint.h> +#include "ft_s_struct.h" + +int32_t ft_e_lcom(t_lcom *lcom, + t_msh *msh); + +#endif diff --git a/src/ft_m_funptr.c b/src/ft_m_funptr.c index 4307d3c..ac40491 100644 --- a/src/ft_m_funptr.c +++ b/src/ft_m_funptr.c @@ -10,6 +10,7 @@ /* */ /* ************************************************************************** */ +#include <libft.h> #include <stdlib.h> #include "ft_b_env.h" #include "ft_d_enum.h" diff --git a/src/ft_m_loop.c b/src/ft_m_loop.c index 3f9488a..d993ac6 100644 --- a/src/ft_m_loop.c +++ b/src/ft_m_loop.c @@ -14,8 +14,10 @@ #include <stdint.h> #include <unistd.h> #include "ft_d_enum.h" +#include "ft_e_lcom.h" #include "ft_m_loop.h" #include "ft_m_prompt.h" +#include "ft_p_line.h" int32_t ft_m_loop(t_msh *msh) @@ -30,7 +32,7 @@ int32_t gnl = get_next_line(STDIN_FILENO, &line); ft_p_line(line, msh); ft_memdel((void*)&line); - ft_e_lcom(msh->lcom, msh); + ft_e_lcom(msh->lcom_head, msh); } return (FT_RET_FINE); } diff --git a/src/ft_p_lcom.c b/src/ft_p_lcom.c index 8c3d6d4..3ea6b16 100644 --- a/src/ft_p_lcom.c +++ b/src/ft_p_lcom.c @@ -12,6 +12,7 @@ #include <libft.h> #include <stdint.h> +#include "ft_s_lcom.h" #include "ft_s_struct.h" int8_t @@ -31,7 +32,7 @@ int8_t { return (-1); } - msh->lcom = msh->lcom.next; + msh->lcom = msh->lcom->next; i++; } return (0); diff --git a/src/ft_p_lcom.h b/src/ft_p_lcom.h index e69de29..245e206 100644 --- a/src/ft_p_lcom.h +++ b/src/ft_p_lcom.h @@ -0,0 +1,23 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_p_lcom.h :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rbousset <marvin@42.fr> +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/02/14 17:19:27 by rbousset #+# #+# */ +/* Updated: 2020/02/14 17:19:29 by rbousset ### ########lyon.fr */ +/* */ +/* ************************************************************************** */ + +#ifndef FT_P_LCOM_H +#define FT_P_LCOM_H + +#include <stdint.h> +#include "ft_s_struct.h" + +int8_t ft_p_lcom(const char line[], + const int64_t count, + t_msh *msh); + +#endif diff --git a/src/ft_p_line.c b/src/ft_p_line.c index 8d75547..8670231 100644 --- a/src/ft_p_line.c +++ b/src/ft_p_line.c @@ -13,6 +13,7 @@ #include <libft.h> #include <stdlib.h> #include "ft_d_enum.h" +#include "ft_p_lcom.h" #include "ft_p_line.h" #include "ft_s_struct.h" diff --git a/src/ft_s_destroy.c b/src/ft_s_destroy.c index 02336d3..8d93250 100644 --- a/src/ft_s_destroy.c +++ b/src/ft_s_destroy.c @@ -17,6 +17,6 @@ void ft_s_destroy(t_msh *msh) { ft_memdel((void*)&msh->ps_one); - ft_memdel((void*)&msh->bu_ref); + ft_delwords(msh->bu_ref); ft_memdel((void*)&msh); } diff --git a/src/ft_s_init.c b/src/ft_s_init.c index c9e4845..c6f22ba 100644 --- a/src/ft_s_init.c +++ b/src/ft_s_init.c @@ -32,7 +32,7 @@ t_msh ft_strlcpy(msh->ps_one, FT_PS_ONE, ft_strlen(FT_PS_ONE) + 1); msh->envp = envp; msh->ret = 0; - ft_m_funptr(msh); + ft_init_buptr(msh); msh->lcom = NULL; msh->lcom_head = msh->lcom; return (msh); diff --git a/src/ft_s_lcom.c b/src/ft_s_lcom.c index 19e503b..737c6eb 100644 --- a/src/ft_s_lcom.c +++ b/src/ft_s_lcom.c @@ -17,19 +17,19 @@ t_lcom *ft_lcom_new(const char word[]) { - t_lcom nlcom; - char **words + t_lcom *nlcom; + char **words; - /* if (!(nlcom = (t_lcom*)malloc(sizeof(t_lcom)))) */ - /* { */ - /* return (NULL); */ - /* } */ + if (!(nlcom = (t_lcom*)malloc(sizeof(t_lcom)))) + { + return (NULL); + } if (!(words = ft_split(word, ' '))) { return (NULL); } - nlcom.com = words[0]; - nlcom.args = words + 1; - nlcom.next = NULL; - return (&nlcom); + nlcom->com = words[0]; + nlcom->args = words + 1; + nlcom->next = NULL; + return (nlcom); } diff --git a/src/ft_s_lcom.h b/src/ft_s_lcom.h index 186f93d..14a0c39 100644 --- a/src/ft_s_lcom.h +++ b/src/ft_s_lcom.h @@ -13,6 +13,8 @@ #ifndef FT_S_LCOM_H #define FT_S_LCOM_H -t_com *ft_lcom_new(const char word[]); +#include "ft_s_struct.h" + +t_lcom *ft_lcom_new(const char word[]); #endif diff --git a/src/ft_s_struct.h b/src/ft_s_struct.h index 6f3cf21..750c95b 100644 --- a/src/ft_s_struct.h +++ b/src/ft_s_struct.h @@ -20,7 +20,7 @@ typedef struct s_lcom { char *com; char **args; - struct s_com *next; + struct s_lcom *next; } t_lcom; typedef struct s_msh |