diff options
author | JozanLeClerc <bousset.rudy@gmail.com> | 2020-09-11 16:56:23 +0200 |
---|---|---|
committer | JozanLeClerc <bousset.rudy@gmail.com> | 2020-09-11 16:56:23 +0200 |
commit | 0ab424df075f09aac376890a9a5a73cb74e053bf (patch) | |
tree | 7dab35480c6005f3bbc7ed864410bf04da9dd0bd /src | |
parent | TODO update (diff) | |
download | 42-minishell-0ab424df075f09aac376890a9a5a73cb74e053bf.tar.gz 42-minishell-0ab424df075f09aac376890a9a5a73cb74e053bf.tar.bz2 42-minishell-0ab424df075f09aac376890a9a5a73cb74e053bf.tar.xz 42-minishell-0ab424df075f09aac376890a9a5a73cb74e053bf.tar.zst 42-minishell-0ab424df075f09aac376890a9a5a73cb74e053bf.zip |
alias in progress
Diffstat (limited to 'src')
-rw-r--r-- | src/b_alias.c | 23 | ||||
-rw-r--r-- | src/b_alias.h | 22 | ||||
-rw-r--r-- | src/b_builtins.h | 1 | ||||
-rw-r--r-- | src/d_define.h | 2 | ||||
-rw-r--r-- | src/d_enum.h | 1 | ||||
-rw-r--r-- | src/m_funptr.c | 3 | ||||
-rw-r--r-- | src/s_init.c | 6 | ||||
-rw-r--r-- | src/s_struct.h | 22 |
8 files changed, 68 insertions, 12 deletions
diff --git a/src/b_alias.c b/src/b_alias.c new file mode 100644 index 0000000..6848b68 --- /dev/null +++ b/src/b_alias.c @@ -0,0 +1,23 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* b_alias.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 <stdint.h> + +#include "s_struct.h" + +uint8_t + b_alias(char *args[], t_msh *msh) +{ + (void)args; + (void)msh; + return (0); +} diff --git a/src/b_alias.h b/src/b_alias.h new file mode 100644 index 0000000..a4aa1d8 --- /dev/null +++ b/src/b_alias.h @@ -0,0 +1,22 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* b_alias.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 B_ALIAS_H +#define B_ALIAS_H + +#include <stdint.h> + +#include "s_struct.h" + +uint8_t b_alias(char *args[], t_msh *msh); + +#endif diff --git a/src/b_builtins.h b/src/b_builtins.h index 0cb430a..62b2a41 100644 --- a/src/b_builtins.h +++ b/src/b_builtins.h @@ -13,6 +13,7 @@ #ifndef B_BUILTINS_H #define B_BUILTINS_H +#include "b_alias.h" #include "b_cd.h" #include "b_echo.h" #include "b_env.h" diff --git a/src/d_define.h b/src/d_define.h index 0e62f36..897b720 100644 --- a/src/d_define.h +++ b/src/d_define.h @@ -19,7 +19,7 @@ ** ====== CLASSICS ====== */ -#define FT_BUILTINS "echo|cd|pwd|export|unset|env|exit|type|[" +#define FT_BUILTINS "echo|cd|pwd|export|unset|env|exit|type|[|alias" /* ** ====== PSX ====== diff --git a/src/d_enum.h b/src/d_enum.h index e5078a7..69d34c9 100644 --- a/src/d_enum.h +++ b/src/d_enum.h @@ -50,6 +50,7 @@ enum FT_ID_EXIT, FT_ID_TYPE, FT_ID_SQB, + FT_ID_ALIAS, FT_BUILTINS_COUNT }; diff --git a/src/m_funptr.c b/src/m_funptr.c index a6b31f2..1983e73 100644 --- a/src/m_funptr.c +++ b/src/m_funptr.c @@ -31,7 +31,8 @@ void msh->bu_ptr[FT_ID_EXIT] = b_exit; msh->bu_ptr[FT_ID_TYPE] = b_type; msh->bu_ptr[FT_ID_SQB] = b_sqb; - if (!(msh->bu_ref = ft_split(FT_BUILTINS, '|'))) + msh->bu_ptr[FT_ID_ALIAS] = b_alias; + if ((msh->bu_ref = ft_split(FT_BUILTINS, '|')) == NULL) { f_alloc_and_destroy_msh(msh); } diff --git a/src/s_init.c b/src/s_init.c index cfe2eeb..fb63548 100644 --- a/src/s_init.c +++ b/src/s_init.c @@ -163,11 +163,10 @@ t_msh char cwd[PATH_MAX]; t_msh *msh; - if (!(msh = (t_msh*)malloc(sizeof(t_msh)))) + if ((msh = (t_msh*)malloc(sizeof(t_msh))) == NULL) return (NULL); - if (!(msh->shname = ft_strdup(argv[0]))) + if ((msh->shname = ft_strdup(argv[0])) == NULL) return (NULL); - /* TODO: shname: care about "./", try with symlinks */ msh->envp = NULL; if ((msh->envp = dupenv(envp)) == NULL) return (NULL); @@ -177,6 +176,7 @@ t_msh msh->com = NULL; msh->pipes = NULL; msh->vars = NULL; + msh->alias = NULL; set_cwd(cwd, msh); if ((msh->cwd = ft_strdup(cwd)) == NULL) return (NULL); diff --git a/src/s_struct.h b/src/s_struct.h index 31c80fc..b45af9f 100644 --- a/src/s_struct.h +++ b/src/s_struct.h @@ -18,6 +18,20 @@ #include "d_define.h" +typedef struct s_lalias +{ + char *name; + char *value; + struct s_lalias *next; +} t_lalias; + +typedef struct s_lvars +{ + struct s_lvars *next; + char *name; + char *val; +} t_lvars; + /* ** redir(int8_t) index ** ------------------- @@ -27,13 +41,6 @@ ** 0: means no redirection */ -typedef struct s_lvars -{ - struct s_lvars *next; - char *name; - char *val; -} t_lvars; - typedef struct s_com { char **argv; @@ -71,6 +78,7 @@ typedef struct s_msh struct s_com *com; struct s_lpipes *pipes; struct s_lvars *vars; + struct s_lalias *alias; char **envp; char **bu_ref; char ps[4][1024]; |