modif cd
This commit is contained in:
parent
01d80ba1cd
commit
ad18ecdeac
@ -94,6 +94,8 @@ int find_pwd(t_s_cmd *cmd);
|
||||
void init_s_cmd(t_s_cmd *cmd, char **env);
|
||||
int tab_len(char **tab);
|
||||
int find_len(char *input, int i, char c);
|
||||
int find_it(t_s_cmd *cmd, char *str);
|
||||
|
||||
//real builtin
|
||||
void ft_env(t_s_cmd *cmd, char **env);
|
||||
void ft_exit(t_s_cmd *cmd);
|
||||
|
||||
@ -55,8 +55,12 @@ void del_one(t_s_cmd *cmd)
|
||||
while (cmd->env[find_pwd(cmd)][i] != '/')
|
||||
i--;
|
||||
r = ft_substr(cmd->env[find_pwd(cmd)], 0, i);
|
||||
free(cmd->env[find_pwd(cmd)]);
|
||||
cmd->env[find_pwd(cmd)] = ft_strdup(r);
|
||||
printf("-------------\n");
|
||||
printf("%s\n", cmd->env[find_pwd(cmd)]);
|
||||
printf("%d\n", find_pwd(cmd));
|
||||
// free(cmd->env[find_pwd(cmd)]);
|
||||
cmd->env[find_pwd(cmd)] = r;
|
||||
// cmd->env[find_pwd(cmd)] = ft_strdup(r);
|
||||
free(r);
|
||||
}
|
||||
|
||||
@ -71,6 +75,23 @@ void add_one(t_s_cmd *cmd, char *str)
|
||||
free(r);
|
||||
}
|
||||
|
||||
int find_it(t_s_cmd *cmd, char *str)
|
||||
{
|
||||
int i;
|
||||
|
||||
i = 0;
|
||||
while (cmd->env[i])
|
||||
{
|
||||
if (ft_strncmp(cmd->env[i], str, ft_strlen(str)) == 0)
|
||||
{
|
||||
printf("--->%s\n", cmd->env[i]);
|
||||
return (1);
|
||||
}
|
||||
i++;
|
||||
}
|
||||
return (0);
|
||||
}
|
||||
|
||||
void change_path(t_s_cmd *cmd)
|
||||
{
|
||||
char **tab;
|
||||
@ -78,15 +99,18 @@ void change_path(t_s_cmd *cmd)
|
||||
|
||||
i = 0;
|
||||
tab = ft_split(cmd->args[1], '/');
|
||||
while (cmd->env[i])
|
||||
{
|
||||
if (ft_strncmp(cmd->env[i], "OLDPWD=", 7) == 0)
|
||||
break ;
|
||||
i++;
|
||||
}
|
||||
printf("%d\n", i);
|
||||
// while (cmd->env[i])
|
||||
// {
|
||||
// if (ft_strncmp(cmd->env[i], "OLDPWD=", 7) == 0)
|
||||
// {
|
||||
// printf("--->%s\n", cmd->env[i]);
|
||||
// break ;
|
||||
// }
|
||||
// i++;
|
||||
// }
|
||||
/*if (cmd->env[i])
|
||||
free(cmd->env[i]);*/
|
||||
if (find_it(cmd, "OLDPWD") == 1)
|
||||
cmd->env[i] = ft_strjoin("OLD", cmd->env[find_pwd(cmd)]);
|
||||
i = 0;
|
||||
while (tab[i])
|
||||
@ -106,7 +130,9 @@ void reboot_pwd(t_s_cmd *cmd, int i)
|
||||
while (i > 3)
|
||||
{
|
||||
if (chdir("..") == 0)
|
||||
{
|
||||
del_one(cmd);
|
||||
}
|
||||
i--;
|
||||
}
|
||||
str = ft_substr(cmd->args[1], 2, ft_strlen(cmd->args[1]));
|
||||
@ -123,9 +149,10 @@ void open_directory(t_s_cmd *cmd)
|
||||
j = tab_len(str);
|
||||
if (!cmd->args[1])
|
||||
{
|
||||
while (j-- > 3)
|
||||
if (chdir("..") == 0)
|
||||
del_one(cmd);
|
||||
reboot_pwd(cmd, j);
|
||||
// while (j-- > 3)
|
||||
// if (chdir("..") == 0)
|
||||
// del_one(cmd);
|
||||
}
|
||||
if (tab_len(cmd->args) == 2)
|
||||
{
|
||||
|
||||
Loading…
Reference in New Issue
Block a user