diff options
author | 2017-11-09 23:02:13 +0000 | |
---|---|---|
committer | 2017-11-09 23:02:13 +0000 | |
commit | 9bb2dcbc0365cf9b670be9293b45ba5573004d5c (patch) | |
tree | e9c604a1d7ee7fbdde1368ce27961b3b2438d5a9 | |
parent | Use the proper macros in AUTHORS, and delete the bogus BUGS section. (diff) | |
download | wireguard-openbsd-9bb2dcbc0365cf9b670be9293b45ba5573004d5c.tar.xz wireguard-openbsd-9bb2dcbc0365cf9b670be9293b45ba5573004d5c.zip |
If we successfully change the directory, set PWD too to give the shell a
hint in case of symlinks.
-rw-r--r-- | usr.bin/tmux/window.c | 15 |
1 files changed, 10 insertions, 5 deletions
diff --git a/usr.bin/tmux/window.c b/usr.bin/tmux/window.c index b5023cb98a2..46c63285e88 100644 --- a/usr.bin/tmux/window.c +++ b/usr.bin/tmux/window.c @@ -1,4 +1,4 @@ -/* $OpenBSD: window.c,v 1.206 2017/10/12 11:32:27 nicm Exp $ */ +/* $OpenBSD: window.c,v 1.207 2017/11/09 23:02:13 nicm Exp $ */ /* * Copyright (c) 2007 Nicholas Marriott <nicholas.marriott@gmail.com> @@ -935,10 +935,13 @@ window_pane_spawn(struct window_pane *wp, int argc, char **argv, proc_clear_signals(server_proc, 1); sigprocmask(SIG_SETMASK, &oldset, NULL); - if (chdir(wp->cwd) != 0) { - if ((home = find_home()) == NULL || chdir(home) != 0) - chdir("/"); - } + cwd = NULL; + if (chdir(wp->cwd) == 0) + cwd = wp->cwd; + else if ((home = find_home()) != NULL && chdir(home) == 0) + cwd = home; + else + chdir("/"); if (tcgetattr(STDIN_FILENO, &tio2) != 0) fatal("tcgetattr failed"); @@ -953,6 +956,8 @@ window_pane_spawn(struct window_pane *wp, int argc, char **argv, if (path != NULL) environ_set(env, "PATH", "%s", path); + if (cwd != NULL) + environ_set(env, "PWD", "%s", cwd); environ_set(env, "TMUX_PANE", "%%%u", wp->id); environ_push(env); |