From 117e00a55e1487941a6ec12956b2f745c10b6069 Mon Sep 17 00:00:00 2001 From: Philippe-Adrien Nousse Date: Sun, 15 Jul 2018 08:59:56 +0200 Subject: [PATCH] original install script --- tools/install.sh | 69 +++++++++++++++++++++++++++++------------------- 1 file changed, 42 insertions(+), 27 deletions(-) diff --git a/tools/install.sh b/tools/install.sh index b3cfb825..b0673afe 100755 --- a/tools/install.sh +++ b/tools/install.sh @@ -20,14 +20,15 @@ main() { NORMAL="" fi - # Only enable exit-on-error after the non-critical colorization stuff, + # Only enable exit-on-error after the non-critical colorization +stuff, # which may fail on systems lacking tput or terminfo set -e if ! command -v zsh >/dev/null 2>&1; then - printf "${YELLOW}Zsh is not installed!${NORMAL} Installing zsh\n" - sudo apt-get install zsh -y - + printf "${YELLOW}Zsh is not installed!${NORMAL} Please install zsh +first!\n" + exit fi if [ ! -n "$ZSH" ]; then @@ -40,14 +41,16 @@ main() { exit fi - printf "${BLUE}Cloning Oh My Zsh...${NORMAL}\n" - sudo apt-get install -y fonts-powerline - - # Prevent the cloned repository from having insecure permissions. Failing to do - # so causes compinit() calls to fail with "command not found: compdef" errors - # for users with insecure umasks (e.g., "002", allowing group writability). Note - # that this will be ignored under Cygwin by default, as Windows ACLs take - # precedence over umasks except for filesystems mounted with option "noacl". + # Prevent the cloned repository from having insecure permissions. +Failing to do + # so causes compinit() calls to fail with "command not found: +compdef" errors + # for users with insecure umasks (e.g., "002", allowing group +writability). Note + # that this will be ignored under Cygwin by default, as Windows ACLs +take + # precedence over umasks except for filesystems mounted with option +"noacl". umask g-w,o-w printf "${BLUE}Cloning Oh My Zsh...${NORMAL}\n" @@ -59,11 +62,13 @@ main() { if [ "$OSTYPE" = cygwin ]; then if git --version | grep msysgit > /dev/null; then echo "Error: Windows/MSYS Git is not supported on Cygwin" - echo "Error: Make sure the Cygwin git package is installed and is first on the path" + echo "Error: Make sure the Cygwin git package is installed and +is first on the path" exit 1 fi fi - env git clone --depth=1 http://git.adphi.net/Adphi/oh-my-zsh.git $ZSH || { + env git clone --depth=1 +https://github.com/robbyrussell/oh-my-zsh.git "$ZSH" || { printf "Error: git clone of oh-my-zsh repo failed\n" exit 1 } @@ -71,28 +76,35 @@ main() { printf "${BLUE}Looking for an existing zsh config...${NORMAL}\n" if [ -f ~/.zshrc ] || [ -h ~/.zshrc ]; then - printf "${YELLOW}Found ~/.zshrc.${NORMAL} ${GREEN}Backing up to ~/.zshrc.pre-oh-my-zsh${NORMAL}\n"; + printf "${YELLOW}Found ~/.zshrc.${NORMAL} ${GREEN}Backing up to +~/.zshrc.pre-oh-my-zsh${NORMAL}\n"; mv ~/.zshrc ~/.zshrc.pre-oh-my-zsh; fi - printf "${BLUE}Using the Oh My Zsh template file and adding it to ~/.zshrc${NORMAL}\n" - cp $ZSH/templates/zshrc.zsh-template ~/.zshrc + printf "${BLUE}Using the Oh My Zsh template file and adding it to +~/.zshrc${NORMAL}\n" + cp "$ZSH"/templates/zshrc.zsh-template ~/.zshrc sed "/^export ZSH=/ c\\ - export ZSH=$ZSH + export ZSH=\"$ZSH\" " ~/.zshrc > ~/.zshrc-omztemp mv -f ~/.zshrc-omztemp ~/.zshrc - # If this user's login shell is not already "zsh", attempt to switch. + # If this user's login shell is not already "zsh", attempt to +switch. TEST_CURRENT_SHELL=$(expr "$SHELL" : '.*/\(.*\)') if [ "$TEST_CURRENT_SHELL" != "zsh" ]; then - # If this platform provides a "chsh" command (not Cygwin), do it, man! + # If this platform provides a "chsh" command (not Cygwin), do it, +man! if hash chsh >/dev/null 2>&1; then - printf "${BLUE}Time to change your default shell to zsh!${NORMAL}\n" + printf "${BLUE}Time to change your default shell to +zsh!${NORMAL}\n" chsh -s $(grep /zsh$ /etc/shells | tail -1) # Else, suggest the user do so manually. else - printf "I can't change your shell automatically because this system does not have chsh.\n" - printf "${BLUE}Please manually change your default shell to zsh!${NORMAL}\n" + printf "I can't change your shell automatically because this +system does not have chsh.\n" + printf "${BLUE}Please manually change your default shell to +zsh!${NORMAL}\n" fi fi @@ -102,17 +114,20 @@ main() { echo ' / __ \/ __ \ / __ `__ \/ / / / /_ / / ___/ __ \ ' echo '/ /_/ / / / / / / / / / / /_/ / / /_(__ ) / / / ' echo '\____/_/ /_/ /_/ /_/ /_/\__, / /___/____/_/ /_/ ' - echo ' /____/ ....is now installed!' + echo ' /____/ ....is +now installed!' echo '' echo '' - echo 'Please look over the ~/.zshrc file to select plugins, themes, and options.' + echo 'Please look over the ~/.zshrc file to select plugins, themes, +and options.' echo '' echo 'p.s. Follow us at https://twitter.com/ohmyzsh.' echo '' - echo 'p.p.s. Get stickers and t-shirts at https://shop.planetargon.com.' + echo 'p.p.s. Get stickers and t-shirts at +https://shop.planetargon.com.' echo '' printf "${NORMAL}" - env zsh + env zsh -l } main