unsetenv OK

This commit is contained in:
Jack Halford 2017-03-24 23:05:52 +01:00
parent 3c4b194553
commit 79ac0a8edc
5 changed files with 22 additions and 39 deletions

View file

@ -6,7 +6,7 @@
/* By: jhalford <jhalford@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2017/03/21 16:32:26 by jhalford #+# #+# */
/* Updated: 2017/03/24 20:08:12 by jhalford ### ########.fr */
/* Updated: 2017/03/24 22:59:28 by jhalford ### ########.fr */
/* */
/* ************************************************************************** */
@ -15,9 +15,6 @@
int fd_replace(int fd1, int fd2)
{
if (fd1 != fd2)
{
DG("%i ---> %i", fd2, fd1);
return (dup2_close(fd1, fd2));
}
return (0);
}

View file

@ -6,7 +6,7 @@
/* By: jhalford <jhalford@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2016/12/03 11:57:53 by jhalford #+# #+# */
/* Updated: 2017/03/21 15:28:51 by jhalford ### ########.fr */
/* Updated: 2017/03/24 23:03:58 by jhalford ### ########.fr */
/* */
/* ************************************************************************** */
@ -20,6 +20,13 @@
#define CDERR_2 "cd: HOME not set"
#define CDERR_3 "cd: too many arguments{eoc}"
static g_cliopts g_cdotps =
{
{'P', NULL, CD_OPT_P, CD_OPT_L, NULL},
{'L', NULL, CD_OPT_L, CD_OPT_P, NULL},
{0, NULL, 0, 0, NULL},
}
static char *builtin_cd_special(char *const av[], char *const env[])
{
char *target;
@ -44,30 +51,13 @@ static char *builtin_cd_special(char *const av[], char *const env[])
return (target);
}
static int builtin_cd_opts(char *const av[], int *opts)
void setwd(char *var)
{
int i;
int j;
char *cwd;
i = 1;
if (av)
while (av[i] && av[i][0] == '-' && av[i][1])
{
j = 0;
while (av[i][++j])
{
if (av[i][j] == 'P')
*opts = CDOPT_P;
else if (av[i][j] == 'L')
*opts = CDOPT_L;
else if (av[i][j] == '-')
return (i + 1);
else
return (i);
}
++i;
}
return (i);
cwd = getcwd(NULL, 0);
builtin_setenv(path, (char*[4]){"setenv", var, cwd, NULL}, envp);
free(cwd);
}
int builtin_cd(const char *path,
@ -76,15 +66,13 @@ int builtin_cd(const char *path,
int i;
int opts;
char *target;
char *cwd;
opts = CDOPT_L;
data->flag = CD_OPT_L;
if (cliopts(av, g_cdopts, &data))
i = builtin_cd_opts(av, &opts);
setwd("OLDPWD");
if (!(target = builtin_cd_special(av + i, envp)))
return (1);
cwd = getcwd(NULL, 0);
builtin_setenv(path, (char*[4]){"setenv", "OLDPWD", cwd, NULL}, envp);
free(cwd);
if (chdir(target))
{
SH_ERR(CDERR_1, target);
@ -92,9 +80,7 @@ int builtin_cd(const char *path,
}
else if (target != av[i])
ft_printf("%s\n", target);
cwd = getcwd(NULL, 0);
builtin_setenv(path, (char*[4]){"setenv", "PWD", cwd, NULL}, envp);
free(cwd);
setwd("PWD");
if (!ft_strcmp(*(av + i), "-"))
free(target);
return (0);

View file

@ -6,7 +6,7 @@
/* By: jhalford <jhalford@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2016/11/28 14:25:17 by jhalford #+# #+# */
/* Updated: 2017/03/23 18:26:59 by jhalford ### ########.fr */
/* Updated: 2017/03/24 22:43:49 by jhalford ### ########.fr */
/* */
/* ************************************************************************** */

View file

@ -6,7 +6,7 @@
/* By: jhalford <jhalford@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2016/11/28 14:29:17 by jhalford #+# #+# */
/* Updated: 2017/03/23 18:24:41 by jhalford ### ########.fr */
/* Updated: 2017/03/24 22:59:17 by jhalford ### ########.fr */
/* */
/* ************************************************************************** */
@ -29,7 +29,7 @@ int builtin_unsetenv(const char *path, char *const av[], char *const envp[])
while (*env && (*env)[j])
{
if (ft_strcmp((*env)[j], av[i]) == '='
&& ft_strlen(av[1]) == ft_strlenchr((*env)[i], '='))
&& ft_strlen(av[i]) == ft_strlenchr((*env)[j], '='))
ft_sstrdel(*env, j);
else
j++;

View file

@ -6,7 +6,7 @@
/* By: wescande <wescande@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2017/03/07 17:20:53 by wescande #+# #+# */
/* Updated: 2017/03/22 19:23:55 by jhalford ### ########.fr */
/* Updated: 2017/03/24 22:43:37 by jhalford ### ########.fr */
/* */
/* ************************************************************************** */