From 300022642aca488d0fa33f1e1f65756613054a0b Mon Sep 17 00:00:00 2001 From: Koen Punt Date: Sat, 15 Mar 2014 04:32:35 +0100 Subject: [PATCH] git, curl and wget now all in one installer --- install-gitless.sh | 71 -------------------------------------------- install.sh | 73 +++++++++++++++++++++++++++++++++++----------- 2 files changed, 56 insertions(+), 88 deletions(-) delete mode 100755 install-gitless.sh diff --git a/install-gitless.sh b/install-gitless.sh deleted file mode 100755 index 53d40a2..0000000 --- a/install-gitless.sh +++ /dev/null @@ -1,71 +0,0 @@ -#!/bin/bash - -set -e - -fatalExit (){ - echo "$@" && exit 1; -} - -if [ -z "$NVM_SOURCE" ]; then - NVM_SOURCE="https://raw.github.com/creationix/nvm/master/nvm.sh" -fi - -if [ -z "$NVM_DIR" ]; then - NVM_DIR="$HOME/.nvm" -fi - -# Downloading to $NVM_DIR -mkdir -p "$NVM_DIR" -echo -e "\r=> Downloading... \c" - -# Detect if curl or wget is installed to download NVM_SOURCE -if type curl > /dev/null 2>&1; then - curl --silent "$NVM_SOURCE" -o "$NVM_DIR/nvm.sh" || fatalExit "Failed downloading $NVM_SOURCE"; -elif type wget > /dev/null 2>&1; then - wget --quiet "$NVM_SOURCE" -O "$NVM_DIR/nvm.sh" || fatalExit "Failed downloading $NVM_SOURCE"; -else - fatalExit "Must have curl or wget to install nvm"; -fi - -echo "Downloaded" - -echo - -# Detect profile file if not specified as environment variable (eg: PROFILE=~/.myprofile). -if [ -z "$PROFILE" ]; then - if [ -f "$HOME/.bash_profile" ]; then - PROFILE="$HOME/.bash_profile" - elif [ -f "$HOME/.zshrc" ]; then - PROFILE="$HOME/.zshrc" - elif [ -f "$HOME/.profile" ]; then - PROFILE="$HOME/.profile" - fi -fi - -SOURCE_STR="[ -s \"$NVM_DIR/nvm.sh\" ] && . \"$NVM_DIR/nvm.sh\" # This loads NVM" - -if [ -z "$PROFILE" ] || [ ! -f "$PROFILE" ] ; then - if [ -z $PROFILE ]; then - echo "=> Profile not found. Tried ~/.bash_profile ~/.zshrc and ~/.profile." - echo "=> Create one of them and run this script again" - else - echo "=> Profile $PROFILE not found" - echo "=> Create it (touch $PROFILE) and run this script again" - fi - echo " OR" - echo "=> Append the following line to the correct file yourself:" - echo - echo " $SOURCE_STR" - echo -else - if ! grep -qc 'nvm.sh' $PROFILE; then - echo "=> Appending source string to $PROFILE" - echo "" >> "$PROFILE" - echo $SOURCE_STR >> "$PROFILE" - else - echo "=> Source string already in $PROFILE" - fi -fi - -echo "=> Close and reopen your terminal to start using NVM" - diff --git a/install.sh b/install.sh index 2804803..68fce91 100755 --- a/install.sh +++ b/install.sh @@ -2,34 +2,73 @@ set -e -if [ ! "$NVM_SOURCE" ]; then - NVM_SOURCE="https://github.com/creationix/nvm.git" -fi +has() { + type "$1" > /dev/null 2>&1 + return $? +} -if [ ! "$NVM_DIR" ]; then +if [ -z "$NVM_DIR" ]; then NVM_DIR="$HOME/.nvm" fi -if ! hash git 2>/dev/null; then - echo >&2 "You need to install git - visit http://git-scm.com/downloads" - echo >&2 "or, use install-gitless.sh instead." - exit 1 -fi +download_file() { + # download_file source destination + if has "curl"; then + curl --silent "$1" -o "$2" + elif has "wget"; then + wget --quiet "$1" -O "$2" + else + return 1 + fi +} -if [ -d "$NVM_DIR" ]; then - echo "=> NVM is already installed in $NVM_DIR, trying to update" - echo -e "\r=> \c" - cd "$NVM_DIR" && git pull -else - # Cloning to $NVM_DIR +install_from_git() { + if [ -z "$NVM_SOURCE" ]; then + NVM_SOURCE="https://github.com/creationix/nvm.git" + fi + + if [ -d "$NVM_DIR/.git" ]; then + echo "=> NVM is already installed in $NVM_DIR, trying to update" + echo -e "\r=> \c" + cd "$NVM_DIR" && git pull + else + # Cloning to $NVM_DIR + mkdir -p "$NVM_DIR" + git clone "$NVM_SOURCE" "$NVM_DIR" + fi +} + +install_as_script() { + if [ -z "$NVM_SOURCE" ]; then + NVM_SOURCE="https://raw.github.com/creationix/nvm/master/nvm.sh" + fi + + # Downloading to $NVM_DIR mkdir -p "$NVM_DIR" - git clone "$NVM_SOURCE" "$NVM_DIR" + if [ -d "$NVM_DIR/nvm.sh" ]; then + echo "=> NVM is already installed in $NVM_DIR, trying to update" + else + echo "=> Downloading NVM to '$NVM_DIR'" + fi + download_file "$NVM_SOURCE" "$NVM_DIR/nvm.sh" || { + echo >&2 "Failed.." + return 1 + } +} + +if has "git"; then + install_from_git +else + install_as_script || { + echo >&2 -e "You need git, curl or wget to install NVM" + exit 1 + } fi echo # Detect profile file if not specified as environment variable (eg: PROFILE=~/.myprofile). -if [ ! "$PROFILE" ]; then +if [ -z "$PROFILE" ]; then if [ -f "$HOME/.bash_profile" ]; then PROFILE="$HOME/.bash_profile" elif [ -f "$HOME/.zshrc" ]; then