about summary refs log tree commit diff
diff options
context:
space:
mode:
authorBarton E. Schaefer <schaefer@zsh.org>2013-08-18 20:24:45 -0700
committerBarton E. Schaefer <schaefer@zsh.org>2013-08-18 20:24:45 -0700
commit935758ab7febbf1c46323d530fae2bae1dfd23d5 (patch)
treed1508c9d7cabd12b6fff75f244541dd3b24c2c00
parent40a881569fed17177fbd73079dd4d3849517567c (diff)
downloadzsh-935758ab7febbf1c46323d530fae2bae1dfd23d5.tar.gz
zsh-935758ab7febbf1c46323d530fae2bae1dfd23d5.tar.xz
zsh-935758ab7febbf1c46323d530fae2bae1dfd23d5.zip
31637: be more selective about retry of lchdir() in cd_do_chdir()
Change of directory should not be retried relative to the current directory
when it has already failed along some path that does not refer to the
current directory.
-rw-r--r--ChangeLog6
-rw-r--r--Src/builtin.c3
2 files changed, 8 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index d27000788..74e0ebeb5 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2013-08-17  Barton E. Schaefer  <schaefer@zsh.org>
+
+	* 31637: Src/builtin.c: change of directory should not be retried
+	relative to the current directory when it has already failed along
+	some path that does not refer to the current directory.
+
 2013-08-11  Peter Stephenson  <p.w.stephenson@ntlworld.com>
 
 	* 31650: Src/utils.c: use zlong for mailcheck parameters to
diff --git a/Src/builtin.c b/Src/builtin.c
index 3159975e3..f8be4acc9 100644
--- a/Src/builtin.c
+++ b/Src/builtin.c
@@ -1125,7 +1125,8 @@ cd_try_chdir(char *pfix, char *dest, int hard)
      * argument to cd relatively.  This is useful if the cwd
      * or a parent directory is renamed in the interim.
      */
-    if (lchdir(buf, NULL, hard) && lchdir(dest, NULL, hard)) {
+    if (lchdir(buf, NULL, hard) &&
+	(pfix || *dest == '/' || lchdir(dest, NULL, hard))) {
 	free(buf);
 	return NULL;
     }