summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPeter Stephenson <p.w.stephenson@ntlworld.com>2024-07-28 20:33:07 +0100
committerPeter Stephenson <p.w.stephenson@ntlworld.com>2024-07-28 20:33:07 +0100
commit0bb140f9911851e9712dba311925f9c9ab521fd2 (patch)
treeaccadafa16f09e9aff93f3ba4a3d3a46fb9ca0d5
parent09c5b10dc2affbe4e46f69e64d573b197c14b988 (diff)
downloadzsh-0bb140f9911851e9712dba311925f9c9ab521fd2.tar.gz
zsh-0bb140f9911851e9712dba311925f9c9ab521fd2.zip
52999: import OLDPWD from environment if set
-rw-r--r--ChangeLog5
-rw-r--r--Src/init.c6
2 files changed, 10 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 5c6270d05..22ccce77a 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2024-07-28 Peter Stephenson <p.w.stephenson@ntlworld.com>
+
+ * 52999: Franklin Yu (adapted): Src/init.c: Import OLDPWD from
+ the environment if set.
+
2024-07-04 Jun-ichi Takimoto <takimoto-j@kba.biglobe.ne.jp>
* 52985: Src/exec.c: avoid adding original param to restorelist
diff --git a/Src/init.c b/Src/init.c
index ec21521b1..0aecb5db9 100644
--- a/Src/init.c
+++ b/Src/init.c
@@ -1245,7 +1245,11 @@ setupvals(char *cmd, char *runscript, char *zsh_name)
pwd = metafy(zgetcwd(), -1, META_DUP);
}
- oldpwd = ztrdup(pwd); /* initialize `OLDPWD' = `PWD' */
+ oldpwd = zgetenv("OLDPWD");
+ if (oldpwd == NULL)
+ oldpwd = ztrdup(pwd); /* initialize `OLDPWD' = `PWD' */
+ else
+ oldpwd = ztrdup(oldpwd);
inittyptab(); /* initialize the ztypes table */
initlextabs(); /* initialize lexing tables */