=================================================================== RCS file: /cvsrepo/anoncvs/cvs/src/usr.bin/tmux/window.c,v retrieving revision 1.79 retrieving revision 1.80 diff -c -r1.79 -r1.80 *** src/usr.bin/tmux/window.c 2012/04/08 06:47:26 1.79 --- src/usr.bin/tmux/window.c 2012/05/28 08:55:43 1.80 *************** *** 1,4 **** ! /* $OpenBSD: window.c,v 1.79 2012/04/08 06:47:26 nicm Exp $ */ /* * Copyright (c) 2007 Nicholas Marriott --- 1,4 ---- ! /* $OpenBSD: window.c,v 1.80 2012/05/28 08:55:43 nicm Exp $ */ /* * Copyright (c) 2007 Nicholas Marriott *************** *** 739,761 **** 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); ! execl(_PATH_BSHELL, "sh", "-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"); } --- 739,762 ---- clear_signals(1); log_close(); ! setenv("SHELL", wp->shell, 1); ! ptr = strrchr(wp->shell, '/'); ! 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. */ if (ptr != NULL && *(ptr + 1) != '\0') xasprintf(&argv0, "-%s", ptr + 1); else xasprintf(&argv0, "-%s", wp->shell); execl(wp->shell, argv0, (char *) NULL); fatal("execl failed"); }