diff options
Diffstat (limited to '')
-rw-r--r-- | src/b_cd.c | 25 |
1 files changed, 13 insertions, 12 deletions
@@ -73,7 +73,7 @@ static void { if (ft_strncmp(splited[i], "..", 3) == 0) { - j = ft_strlen(repath); + j = (repath[0] == '\0') ? (0) : (ft_strlen(repath)); while (repath[j] != '/' && j > 0) j--; repath[j] = '\0'; @@ -94,27 +94,28 @@ static void static void b_upgrade_pwd(const char path[], t_msh *msh) { - char *tmp; char **splited; char repath[262144]; char fmt[262144]; b_set_oldpwd(msh); + splited = NULL; repath[0] = '\0'; if (path[0] != '/') - ft_memcpy(repath, msh->cwd, ft_strlen(msh->cwd)); - if ((splited = ft_split(path, '/')) == NULL) + ft_memcpy(repath, msh->cwd, (ft_strlen(msh->cwd) + 1) * sizeof(char)); + if (path[0] == '/' && path[1] == '\0') + ft_memcpy(repath, "/", 2 * sizeof(char)); + else if ((splited = ft_split(path, '/')) == NULL) f_alloc_and_destroy_msh(msh); - b_fill_repath(repath, splited); - repath[0] = (repath[0] == '\0') ? '/' : repath[0]; - ft_delwords(splited); - if ((tmp = u_get_var_value("$PWD", msh)) != NULL) - u_subst_var_value("$PWD", repath, msh); - else + if (splited != NULL) { - ft_sprintf(fmt, "%s=%s", "PWD", repath); - b_export_with_equals(fmt, msh); + b_fill_repath(repath, splited); + ft_delwords(splited); } + repath[0] = (repath[0] == '\0') ? '/' : repath[0]; + ft_printf("[%s]\n", repath); + ft_sprintf(fmt, "%s=%s", "PWD", repath); + b_export_with_equals(fmt, msh); ft_memdel((void*)&msh->cwd); if ((msh->cwd = ft_strdup(repath)) == NULL) f_alloc_and_destroy_msh(msh); |