Terminal.app: changing shell behavior problem?
I'm having problems setting Terminal.app's default shell. It appears to work using a command line utility which sets the shell for the account, however not in Terminal.app's dialog which is for each session. I find that if I set the shell system with with 'chsh', the $SHELL variable in Terminal.app correctly reflects the shell. If I change the shell in Terminal.app only, $SHELL does not correctly reflect the shell, however the shell appears to be the correct shell running. I tried this on a temp account to rule out other interactions and it has the same behavior.
Here is a use case: When I run in Terminal.app:
$ chsh -s /bin/ksh
and invoke Terminal.app, the shell is correctly changed:
$ echo $SHELL
/bin/ksh
The problem is if try similar through Terminal.app->Preferences->General->Shells open with->Command->/bin/ksh
$ echo $SHELL
/bin/bash
Yet when I try command completions with TAB, it reflects ksh behavior.
Therefore, my suspicion is there is something overriding the SHELL environment variable where it is always SHELL=/bin/bash, despite the shell being different than that.
Does anyone know if Apple has a bug here?
Solution 1:
The following information is taken from
- SHELL environment variable still points to zsh after using bash and
- What sets the $SHELL environment variable?
on Unix & Linux, which applies to macOS as well.
You are running the Korn shell if the Terminal preference is set to /bin/ksh
. The output
$ echo $SHELL
/bin/bash
is misleading because the SHELL
variable is set by the login process to
The user's shell, as specified by the password database.
(On macOS it is a user database and not the /etc/passwd
file as on Linux, where that information is stored, but that does not matter.)
You can type
$ echo $0
-ksh
or
$ echo $KSH_VERSION
Version AJM 93u+ 2012-08-01
to verify that you are running the Korn shell.
Setting the shell via
$ chsh -s /bin/ksh
sets the login shell in the user database, and then SHELL
is set accordingly:
$ echo $SHELL
/bin/ksh