summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/b_unset.c26
1 files changed, 7 insertions, 19 deletions
diff --git a/src/b_unset.c b/src/b_unset.c
index d5e7b1b..7e32540 100644
--- a/src/b_unset.c
+++ b/src/b_unset.c
@@ -48,16 +48,14 @@ static t_bool check_valid_identifier(const char arg[])
static void b_realloc_env(size_t skip, t_msh *msh)
{
char **nenvp;
- int8_t skipped;
size_t i;
i = 0;
while (msh->envp[i] != NULL)
i++;
- if (!(nenvp = (char**)malloc(i * sizeof(char*))))
+ if ((nenvp = (char**)malloc(i * sizeof(char*))) == NULL)
f_alloc_and_destroy_msh(msh);
i = 0;
- skipped = 0;
while (msh->envp[i] != NULL)
{
if (i == skip)
@@ -65,13 +63,12 @@ static void b_realloc_env(size_t skip, t_msh *msh)
i += 1;
if (msh->envp[i] == NULL)
break ;
- skipped = 1;
}
- if (!(nenvp[i - skipped] = ft_strdup(msh->envp[i])))
+ if ((nenvp[i - (i > skip)] = ft_strdup(msh->envp[i])) == NULL)
f_alloc_and_destroy_msh(msh);
i++;
}
- nenvp[i - 1] = 0;
+ nenvp[i - 1] = NULL;
ft_delwords(msh->envp);
msh->envp = nenvp;
}
@@ -97,18 +94,9 @@ static t_bool b_removed_from_env(const char arg[], t_msh *msh)
return (FALSE);
}
-static void b_remove_it(const char arg[], t_msh *msh)
-{
- if (b_removed_from_env(arg, msh) == FALSE)
- {
- lvars_delone(&msh->vars, arg);
- }
-}
-
uint8_t b_unset(char *args[], t_msh *msh)
{
char **ptr;
- t_bool next;
int8_t r;
if (args[0] == NULL)
@@ -117,16 +105,16 @@ uint8_t b_unset(char *args[], t_msh *msh)
ptr = args;
while (*ptr != NULL)
{
- next = FALSE;
if (check_valid_identifier(*ptr) == FALSE)
{
f_fail_identifier("unset", *ptr);
- next = TRUE;
r = 1;
+ ptr++;
+ continue ;
}
- if (next == FALSE)
+ if (b_removed_from_env(*ptr, msh) == FALSE)
{
- b_remove_it(*ptr, msh);
+ lvars_delone(&msh->vars, *ptr);
}
ptr++;
}