diff options
Diffstat (limited to 'src/s_init.c')
-rw-r--r-- | src/s_init.c | 85 |
1 files changed, 85 insertions, 0 deletions
diff --git a/src/s_init.c b/src/s_init.c new file mode 100644 index 0000000..454cb67 --- /dev/null +++ b/src/s_init.c @@ -0,0 +1,85 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* s_init.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 <unistd.h> + +#include "d_define.h" +#include "m_funptr.h" +#include "s_init.h" + +static char + **dupenv_del(char **nenvp, + uint64_t i) +{ + while (i > 0) + { + ft_memdel((void*)&nenvp[i]); + i--; + } + ft_memdel((void*)&nenvp); + return (NULL); +} + +static char + **dupenv(char *const envp[]) +{ + uint64_t i; + char **nenvp; + + i = 0; + while (envp[i]) + { + i++; + } + if (!(nenvp = (char**)malloc((i + 1) * sizeof(char*)))) + { + return (NULL); + } + i = 0; + while (envp[i]) + { + if (!(nenvp[i] = ft_strdup(envp[i]))) + return (dupenv_del(nenvp, i)); + i++; + } + nenvp[i] = NULL; + return (nenvp); +} + +t_msh + *init_msh(char *const argv[], + char *const envp[]) +{ + t_msh *msh; + + if (!(msh = (t_msh*)malloc(sizeof(t_msh)))) + return (NULL); + if (!(msh->ps_one = ft_strdup(FT_PS_ONE))) + return (NULL); + if (!(msh->shname = ft_strdup(argv[0]))) + return (NULL); + /* TODO: shname: care about "./", try with symlinks */ + msh->cwd = NULL; + msh->cwd = getcwd(NULL, 0); + /* TODO: handle getcwd failed */ + msh->envp = NULL; + if (!(msh->envp = dupenv(envp))) + return (NULL); + msh->ret = 0; + init_buptr(msh); + msh->curr = NULL; + msh->vars = NULL; + return (msh); +} |