Check for presence of SHELL environment variable
authorEric Pruitt <eric.pruitt@gmail.com>
Wed, 29 Oct 2014 00:51:42 +0000 (17:51 -0700)
committerRoberto E. Vargas Caballero <k0ga@shike2.com>
Tue, 11 Nov 2014 18:20:56 +0000 (19:20 +0100)
- POSIX states the SHELL environment variable "... shall represent a
  pathname of the user's preferred command language interpreter." As
  such, st should check for its presence when deciding what shell to
  use; just as HOME can be defined to override one's passwd-defined home
  directory, a user should also be able to override their passwd-defined
  shell using the SHELL environment variable.

st.c

diff --git a/st.c b/st.c
index ad52280d62898b01f457600187d6f923aa3e00a9..068fbb3469bd6c11aea544c57516a5d00e7509fe 100644 (file)
--- a/st.c
+++ b/st.c
@@ -1158,7 +1158,10 @@ execsh(void) {
                        die("who are you?\n");
        }
 
-       sh = (pw->pw_shell[0]) ? pw->pw_shell : shell;
+       if (!(sh = getenv("SHELL"))) {
+               sh = (pw->pw_shell[0]) ? pw->pw_shell : shell;
+       }
+
        if(opt_cmd)
                prog = opt_cmd[0];
        else if(utmp)