diff options
| author | Fabian Wolff <fabi.wolff@arcor.de> | 2016-09-26 21:41:42 +0200 | 
|---|---|---|
| committer | Marc Cornellà <marc.cornella@live.com> | 2016-10-03 12:05:10 +0200 | 
| commit | 40bfe5a4124be7b5983756cc81b54a4a4d5846e6 (patch) | |
| tree | 98433290f8cd391b6d2733e4f10b42bc6da0fab8 /tools/check_for_upgrade.sh | |
| parent | 6d975f72589dbb6e44084841cddf9ea153990eb8 (diff) | |
| download | zsh-40bfe5a4124be7b5983756cc81b54a4a4d5846e6.tar.gz zsh-40bfe5a4124be7b5983756cc81b54a4a4d5846e6.tar.bz2 zsh-40bfe5a4124be7b5983756cc81b54a4a4d5846e6.zip  | |
Implement a locking mechanism to avoid multiple update prompts (fixes #3766)
Diffstat (limited to 'tools/check_for_upgrade.sh')
| -rw-r--r-- | tools/check_for_upgrade.sh | 41 | 
1 files changed, 23 insertions, 18 deletions
diff --git a/tools/check_for_upgrade.sh b/tools/check_for_upgrade.sh index bd9aba8be..d1b174c6d 100644 --- a/tools/check_for_upgrade.sh +++ b/tools/check_for_upgrade.sh @@ -29,31 +29,36 @@ fi  # Cancel upgrade if git is unavailable on the system  whence git >/dev/null || return 0 -if [ -f ~/.zsh-update ] +if mkdir "$ZSH/log/update.lock" 2>/dev/null  then -  . ~/.zsh-update +  if [ -f ~/.zsh-update ] +  then +    . ~/.zsh-update -  if [[ -z "$LAST_EPOCH" ]]; then -    _update_zsh_update && return 0; -  fi +    if [[ -z "$LAST_EPOCH" ]]; then +      _update_zsh_update && return 0; +    fi -  epoch_diff=$(($(_current_epoch) - $LAST_EPOCH)) -  if [ $epoch_diff -gt $epoch_target ] -  then -    if [ "$DISABLE_UPDATE_PROMPT" = "true" ] +    epoch_diff=$(($(_current_epoch) - $LAST_EPOCH)) +    if [ $epoch_diff -gt $epoch_target ]      then -      _upgrade_zsh -    else -      echo "[Oh My Zsh] Would you like to check for updates? [Y/n]: \c" -      read line -      if [[ "$line" == Y* ]] || [[ "$line" == y* ]] || [ -z "$line" ]; then +      if [ "$DISABLE_UPDATE_PROMPT" = "true" ] +      then          _upgrade_zsh        else -        _update_zsh_update +        echo "[Oh My Zsh] Would you like to check for updates? [Y/n]: \c" +        read line +        if [[ "$line" == Y* ]] || [[ "$line" == y* ]] || [ -z "$line" ]; then +          _upgrade_zsh +        else +          _update_zsh_update +        fi        fi      fi +  else +    # create the zsh file +    _update_zsh_update    fi -else -  # create the zsh file -  _update_zsh_update + +  rm -r $ZSH/log/update.lock  fi  | 
