summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authornicm <nicm@openbsd.org>2012-05-28 08:55:43 +0000
committernicm <nicm@openbsd.org>2012-05-28 08:55:43 +0000
commitb984cb366988ac467f9ce2a584ca74b7812a26ad (patch)
tree949b44ba77b98c8bbd5c3aa3bc26b1aa35da3e20
parentTrim a double space from template. (diff)
downloadwireguard-openbsd-b984cb366988ac467f9ce2a584ca74b7812a26ad.tar.xz
wireguard-openbsd-b984cb366988ac467f9ce2a584ca74b7812a26ad.zip
Use default-shell not _PATH_BSHELL to spawn commands, pointed out by
Dennis G?nnewig and Thomas Adam.
-rw-r--r--usr.bin/tmux/window.c19
1 files changed, 10 insertions, 9 deletions
diff --git a/usr.bin/tmux/window.c b/usr.bin/tmux/window.c
index 8f3b2eceda3..1a73eef27ff 100644
--- a/usr.bin/tmux/window.c
+++ b/usr.bin/tmux/window.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: window.c,v 1.79 2012/04/08 06:47:26 nicm Exp $ */
+/* $OpenBSD: window.c,v 1.80 2012/05/28 08:55:43 nicm Exp $ */
/*
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
@@ -739,23 +739,24 @@ window_pane_spawn(struct window_pane *wp, const char *cmd, const char *shell,
clear_signals(1);
log_close();
- if (*wp->cmd != '\0') {
- /* Set SHELL but only if it is currently not useful. */
- shell = getenv("SHELL");
- if (checkshell(shell))
- setenv("SHELL", wp->shell, 1);
+ setenv("SHELL", wp->shell, 1);
+ ptr = strrchr(wp->shell, '/');
- execl(_PATH_BSHELL, "sh", "-c", wp->cmd, (char *) NULL);
+ if (*wp->cmd != '\0') {
+ /* Use the command. */
+ if (ptr != NULL && *(ptr + 1) != '\0')
+ xasprintf(&argv0, "%s", ptr + 1);
+ else
+ xasprintf(&argv0, "%s", wp->shell);
+ execl(wp->shell, argv0, "-c", wp->cmd, (char *) NULL);
fatal("execl failed");
}
/* No command; fork a login shell. */
- ptr = strrchr(wp->shell, '/');
if (ptr != NULL && *(ptr + 1) != '\0')
xasprintf(&argv0, "-%s", ptr + 1);
else
xasprintf(&argv0, "-%s", wp->shell);
- setenv("SHELL", wp->shell, 1);
execl(wp->shell, argv0, (char *) NULL);
fatal("execl failed");
}