installer: allow chsh to work in termux

This commit is contained in:
Marc Cornellà 2019-09-08 20:45:06 +02:00
parent f9e133b88a
commit fd4571d1b0
1 changed files with 25 additions and 17 deletions

View File

@ -165,29 +165,37 @@ setup_shell() {
*) echo "Invalid choice. Shell change skipped."; return ;; *) echo "Invalid choice. Shell change skipped."; return ;;
esac esac
# Test for the right location of the "shells" file # Check if we're running on Termux
if [ -f /etc/shells ]; then case "$PREFIX" in
shells_file=/etc/shells *com.termux*) termux=true; zsh=zsh ;;
elif [ -f /usr/share/defaults/etc/shells ]; then # Solus OS *) termux=false ;;
shells_file=/usr/share/defaults/etc/shells esac
else
error "could not find /etc/shells file. Change your default shell manually."
return
fi
# Get the path to the right zsh binary if [ "$termux" != true ]; then
# 1. Use the most preceding one based on $PATH, then check that it's in the shells file # Test for the right location of the "shells" file
# 2. If that fails, get a zsh path from the shells file, then check it actually exists if [ -f /etc/shells ]; then
if ! zsh=$(which zsh) || ! grep -qx "$zsh" "$shells_file"; then shells_file=/etc/shells
if ! zsh=$(grep '^/.*/zsh$' "$shells_file" | tail -1) || [ ! -f "$zsh" ]; then elif [ -f /usr/share/defaults/etc/shells ]; then # Solus OS
error "no zsh binary found or not present in '$shells_file'" shells_file=/usr/share/defaults/etc/shells
error "change your default shell manually." else
error "could not find /etc/shells file. Change your default shell manually."
return return
fi fi
# Get the path to the right zsh binary
# 1. Use the most preceding one based on $PATH, then check that it's in the shells file
# 2. If that fails, get a zsh path from the shells file, then check it actually exists
if ! zsh=$(which zsh) || ! grep -qx "$zsh" "$shells_file"; then
if ! zsh=$(grep '^/.*/zsh$' "$shells_file" | tail -1) || [ ! -f "$zsh" ]; then
error "no zsh binary found or not present in '$shells_file'"
error "change your default shell manually."
return
fi
fi
fi fi
# We're going to change the default shell, so back up the current one # We're going to change the default shell, so back up the current one
if [ -n $SHELL ]; then if [ -n "$SHELL" ]; then
echo $SHELL > ~/.shell.pre-oh-my-zsh echo $SHELL > ~/.shell.pre-oh-my-zsh
else else
grep "^$USER:" /etc/passwd | awk -F: '{print $7}' > ~/.shell.pre-oh-my-zsh grep "^$USER:" /etc/passwd | awk -F: '{print $7}' > ~/.shell.pre-oh-my-zsh