summaryrefslogtreecommitdiffstats
path: root/src/s_init.c
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--src/s_init.c204
1 files changed, 72 insertions, 132 deletions
diff --git a/src/s_init.c b/src/s_init.c
index 1ce73dd..0842f7c 100644
--- a/src/s_init.c
+++ b/src/s_init.c
@@ -15,173 +15,113 @@
#include <stdlib.h>
#include <unistd.h>
#include <limits.h>
-#include <dirent.h>
-#include <errno.h>
#include "b_export_next.h"
#include "d_define.h"
#include "f_fail.h"
#include "m_funptr.h"
-#include "s_init.h"
+#include "s_init_next.h"
#include "u_vars.h"
#include "u_vars_next.h"
-static void
- s_init_sqb_ref_one(t_msh *msh)
+static void s_init_sqb_ref_one(t_msh *msh)
{
- ft_memcpy(msh->sqb_ref[B_ID_SQB_B], B_SQB_B, ft_strlen(B_SQB_B) + 1);
- ft_memcpy(msh->sqb_ref[B_ID_SQB_C], B_SQB_C, ft_strlen(B_SQB_C) + 1);
- ft_memcpy(msh->sqb_ref[B_ID_SQB_D], B_SQB_D, ft_strlen(B_SQB_D) + 1);
- ft_memcpy(msh->sqb_ref[B_ID_SQB_E], B_SQB_E, ft_strlen(B_SQB_E) + 1);
- ft_memcpy(msh->sqb_ref[B_ID_SQB_F], B_SQB_F, ft_strlen(B_SQB_F) + 1);
- ft_memcpy(msh->sqb_ref[B_ID_SQB_H], B_SQB_H, ft_strlen(B_SQB_H) + 1);
- ft_memcpy(msh->sqb_ref[B_ID_SQB_N], B_SQB_N, ft_strlen(B_SQB_N) + 1);
- ft_memcpy(msh->sqb_ref[B_ID_SQB_P], B_SQB_P, ft_strlen(B_SQB_P) + 1);
- ft_memcpy(msh->sqb_ref[B_ID_SQB_R], B_SQB_R, ft_strlen(B_SQB_R) + 1);
- ft_memcpy(msh->sqb_ref[B_ID_SQB_S], B_SQB_S, ft_strlen(B_SQB_S) + 1);
- ft_memcpy(msh->sqb_ref[B_ID_SQB_W], B_SQB_W, ft_strlen(B_SQB_W) + 1);
- ft_memcpy(msh->sqb_ref[B_ID_SQB_X], B_SQB_X, ft_strlen(B_SQB_X) + 1);
- ft_memcpy(msh->sqb_ref[B_ID_SQB_Z], B_SQB_Z, ft_strlen(B_SQB_Z) + 1);
- ft_memcpy(msh->sqb_ref[B_ID_SQB_L_MAJ],
- B_SQB_L_MAJ, ft_strlen(B_SQB_L_MAJ) + 1);
- ft_memcpy(msh->sqb_ref[B_ID_SQB_S_MAJ],
- B_SQB_S_MAJ, ft_strlen(B_SQB_S_MAJ) + 1);
- ft_memcpy(msh->sqb_ref[B_ID_SQB_NT], B_SQB_NT, ft_strlen(B_SQB_NT) + 1);
- ft_memcpy(msh->sqb_ref[B_ID_SQB_OT], B_SQB_OT, ft_strlen(B_SQB_OT) + 1);
- ft_memcpy(msh->sqb_ref[B_ID_SQB_EQUA],
- B_SQB_EQUA, ft_strlen(B_SQB_EQUA) + 1);
- ft_memcpy(msh->sqb_ref[B_ID_SQB_DIFF],
- B_SQB_DIFF, ft_strlen(B_SQB_DIFF) + 1);
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_B], B_SQB_B,
+ (ft_strlen(B_SQB_B) + 1) * sizeof(char));
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_C], B_SQB_C,
+ (ft_strlen(B_SQB_C) + 1) * sizeof(char));
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_D], B_SQB_D,
+ (ft_strlen(B_SQB_D) + 1) * sizeof(char));
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_E], B_SQB_E,
+ (ft_strlen(B_SQB_E) + 1) * sizeof(char));
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_F], B_SQB_F,
+ (ft_strlen(B_SQB_F) + 1) * sizeof(char));
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_H], B_SQB_H,
+ (ft_strlen(B_SQB_H) + 1) * sizeof(char));
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_N], B_SQB_N,
+ (ft_strlen(B_SQB_N) + 1) * sizeof(char));
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_P], B_SQB_P,
+ (ft_strlen(B_SQB_P) + 1) * sizeof(char));
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_R], B_SQB_R,
+ (ft_strlen(B_SQB_R) + 1) * sizeof(char));
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_S], B_SQB_S,
+ (ft_strlen(B_SQB_S) + 1) * sizeof(char));
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_W], B_SQB_W,
+ (ft_strlen(B_SQB_W) + 1) * sizeof(char));
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_X], B_SQB_X,
+ (ft_strlen(B_SQB_X) + 1) * sizeof(char));
}
-static void
- s_init_sqb_ref_two(t_msh *msh)
+static void s_init_sqb_ref_two(t_msh *msh)
{
- ft_memcpy(msh->sqb_ref[B_ID_SQB_EQ], B_SQB_EQ, ft_strlen(B_SQB_EQ) + 1);
- ft_memcpy(msh->sqb_ref[B_ID_SQB_NE], B_SQB_NE, ft_strlen(B_SQB_NE) + 1);
- ft_memcpy(msh->sqb_ref[B_ID_SQB_GT], B_SQB_GT, ft_strlen(B_SQB_GT) + 1);
- ft_memcpy(msh->sqb_ref[B_ID_SQB_GE], B_SQB_GE, ft_strlen(B_SQB_GE) + 1);
- ft_memcpy(msh->sqb_ref[B_ID_SQB_LT], B_SQB_LT, ft_strlen(B_SQB_LT) + 1);
- ft_memcpy(msh->sqb_ref[B_ID_SQB_LE], B_SQB_LE, ft_strlen(B_SQB_LE) + 1);
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_Z], B_SQB_Z,
+ (ft_strlen(B_SQB_Z) + 1) * sizeof(char));
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_L_MAJ], B_SQB_L_MAJ,
+ (ft_strlen(B_SQB_L_MAJ) + 1) * sizeof(char));
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_S_MAJ], B_SQB_S_MAJ,
+ (ft_strlen(B_SQB_S_MAJ) + 1) * sizeof(char));
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_NT], B_SQB_NT,
+ (ft_strlen(B_SQB_NT) + 1) * sizeof(char));
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_OT], B_SQB_OT,
+ (ft_strlen(B_SQB_OT) + 1) * sizeof(char));
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_EQUA], B_SQB_EQUA,
+ (ft_strlen(B_SQB_EQUA) + 1) * sizeof(char));
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_DIFF], B_SQB_DIFF,
+ (ft_strlen(B_SQB_DIFF) + 1) * sizeof(char));
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_EQ], B_SQB_EQ,
+ (ft_strlen(B_SQB_EQ) + 1) * sizeof(char));
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_NE], B_SQB_NE,
+ (ft_strlen(B_SQB_NE) + 1) * sizeof(char));
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_GT], B_SQB_GT,
+ (ft_strlen(B_SQB_GT) + 1) * sizeof(char));
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_GE], B_SQB_GE,
+ (ft_strlen(B_SQB_GE) + 1) * sizeof(char));
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_LT], B_SQB_LT,
+ (ft_strlen(B_SQB_LT) + 1) * sizeof(char));
}
-static char
- **dupenv_del(char **nenvp,
- uint64_t i)
+static void s_init_sqb_ref_thr(t_msh *msh)
{
- 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);
+ (void)ft_memcpy(msh->sqb_ref[B_ID_SQB_LE], B_SQB_LE,
+ (ft_strlen(B_SQB_LE) + 1) * sizeof(char));
}
-static void
- inc_shlvl(t_msh *msh)
+static void s_null_some(t_msh *msh)
{
- char fmt[8];
- char tmp[255];
- char str[255];
- int32_t shlvl;
-
- u_get_var_value(tmp, "$SHLVL", 255, msh);
- if (tmp[0] == C_NUL)
- {
- ft_memcpy(fmt, "SHLVL=1", 8);
- b_export_with_equals(fmt, msh);
- }
- else
- {
- shlvl = ft_atoi(tmp);
- if (shlvl >= 999)
- f_shlvl_too_high(shlvl);
- shlvl = (shlvl >= 999) ? 0 : shlvl;
- shlvl = (shlvl < 0) ? 0 : shlvl + 1;
- ft_itoa_s(str, shlvl);
- u_subst_var_value("$SHLVL", str, msh);
- }
-}
-
-static void
- set_cwd(char cwd[], t_msh *msh)
-{
- char fmt[PATH_MAX];
- DIR *dir;
-
- u_get_var_value(cwd, "$PWD", PATH_MAX, msh);
- if (cwd[0] == C_NUL)
- {
- getcwd(cwd, PATH_MAX);
- ft_sprintf(fmt, "%s=%s", "PWD", cwd);
- b_export_with_equals(fmt, msh);
- return ;
- }
- if ((dir = opendir(cwd)) != NULL)
- closedir(dir);
- else if (errno == ENOENT)
- {
- getcwd(cwd, PATH_MAX);
- ft_sprintf(fmt, "%s=%s", "PWD", cwd);
- b_export_with_equals(fmt, msh);
- return ;
- }
+ msh->fd = 0;
+ msh->curr = NULL;
+ msh->com = NULL;
+ msh->pipes = NULL;
+ msh->vars = NULL;
+ msh->alias = NULL;
+ msh->prev_hist = NULL;
}
-t_msh *init_msh(int32_t argc, char *const argv[], char *const envp[])
+t_msh *s_init_msh(int32_t argc, char *const argv[], char *const envp[])
{
- char cwd[PATH_MAX];
t_msh *msh;
+ char cwd[PATH_MAX];
if ((msh = (t_msh*)malloc(sizeof(t_msh))) == NULL)
return (NULL);
msh->envp = NULL;
- if ((msh->envp = dupenv(envp)) == NULL)
+ if ((msh->envp = s_dupenv(envp)) == NULL)
return (NULL);
msh->argc = argc - 1;
msh->argv = (char**)argv;
msh->ret = 0;
init_buptr(msh);
- msh->fd = 0;
- msh->curr = NULL;
- msh->com = NULL;
- msh->pipes = NULL;
- msh->vars = NULL;
- msh->alias = NULL;
- msh->prev_hist = NULL;
- set_cwd(cwd, msh);
+ s_null_some(msh);
+ s_set_cwd(cwd, msh);
if ((msh->cwd = ft_strdup(cwd)) == NULL)
+ {
+ ft_memdel((void*)&msh);
return (NULL);
+ }
msh->env_fork_tmp[0][0] = '\0';
- inc_shlvl(msh);
+ s_inc_shlvl(msh);
s_init_sqb_ref_one(msh);
s_init_sqb_ref_two(msh);
+ s_init_sqb_ref_thr(msh);
return (msh);
}