diff options
| author | Sébastien M-B <essembeh@gmail.com> | 2013-02-08 19:08:06 +0100 | 
|---|---|---|
| committer | Sébastien M-B <essembeh@gmail.com> | 2013-02-08 19:08:06 +0100 | 
| commit | 2595484a97d85496fdcdca99a23f52eecd9b1b43 (patch) | |
| tree | fffe23d53a2a635f0861047fb058c8a2632414f7 /plugins/virtualenvwrapper | |
| parent | 8d23a3611086e9a13e7ad754c57fa8cc4797bfa9 (diff) | |
| parent | 6e6cf4303712befb5a7fc3918494aefe4a65991f (diff) | |
| download | zsh-2595484a97d85496fdcdca99a23f52eecd9b1b43.tar.gz zsh-2595484a97d85496fdcdca99a23f52eecd9b1b43.tar.bz2 zsh-2595484a97d85496fdcdca99a23f52eecd9b1b43.zip | |
Merge remote-tracking branch 'upstream/master'
Conflicts:
	lib/aliases.zsh
Diffstat (limited to 'plugins/virtualenvwrapper')
| -rw-r--r-- | plugins/virtualenvwrapper/virtualenvwrapper.plugin.zsh | 76 | 
1 files changed, 35 insertions, 41 deletions
| diff --git a/plugins/virtualenvwrapper/virtualenvwrapper.plugin.zsh b/plugins/virtualenvwrapper/virtualenvwrapper.plugin.zsh index a93c8e863..0ed2565b4 100644 --- a/plugins/virtualenvwrapper/virtualenvwrapper.plugin.zsh +++ b/plugins/virtualenvwrapper/virtualenvwrapper.plugin.zsh @@ -1,46 +1,40 @@ -WRAPPER_FOUND=0 -for wrapsource in "/usr/local/bin/virtualenvwrapper.sh" "/etc/bash_completion.d/virtualenvwrapper" ; do -  if [[ -e $wrapsource ]] ; then -    WRAPPER_FOUND=1 -    source $wrapsource +wrapsource=`which virtualenvwrapper_lazy.sh` -    if [[ ! $DISABLE_VENV_CD -eq 1 ]]; then -      # Automatically activate Git projects' virtual environments based on the -      # directory name of the project. Virtual environment name can be overridden -      # by placing a .venv file in the project root with a virtualenv name in it -      function workon_cwd { -          # Check that this is a Git repo -          PROJECT_ROOT=`git rev-parse --show-toplevel 2> /dev/null` -          if (( $? == 0 )); then -              # Check for virtualenv name override -              ENV_NAME=`basename "$PROJECT_ROOT"` -              if [[ -f "$PROJECT_ROOT/.venv" ]]; then -                  ENV_NAME=`cat "$PROJECT_ROOT/.venv"` -              fi -              # Activate the environment only if it is not already active -              if [[ "$VIRTUAL_ENV" != "$WORKON_HOME/$ENV_NAME" ]]; then -                  if [[ -e "$WORKON_HOME/$ENV_NAME/bin/activate" ]]; then -                      workon "$ENV_NAME" && export CD_VIRTUAL_ENV="$ENV_NAME" -                  fi -              fi -          elif [ $CD_VIRTUAL_ENV ]; then -              # We've just left the repo, deactivate the environment -              # Note: this only happens if the virtualenv was activated automatically -              deactivate && unset CD_VIRTUAL_ENV -          fi -          unset PROJECT_ROOT -      } +if [[ -f "$wrapsource" ]]; then +  source $wrapsource -      # New cd function that does the virtualenv magic -      function cd { -          builtin cd "$@" && workon_cwd -      } -    fi +  if [[ ! $DISABLE_VENV_CD -eq 1 ]]; then +    # Automatically activate Git projects' virtual environments based on the +    # directory name of the project. Virtual environment name can be overridden +    # by placing a .venv file in the project root with a virtualenv name in it +    function workon_cwd { +        # Check that this is a Git repo +        PROJECT_ROOT=`git rev-parse --show-toplevel 2> /dev/null` +        if (( $? == 0 )); then +            # Check for virtualenv name override +            ENV_NAME=`basename "$PROJECT_ROOT"` +            if [[ -f "$PROJECT_ROOT/.venv" ]]; then +                ENV_NAME=`cat "$PROJECT_ROOT/.venv"` +            fi +            # Activate the environment only if it is not already active +            if [[ "$VIRTUAL_ENV" != "$WORKON_HOME/$ENV_NAME" ]]; then +                if [[ -e "$WORKON_HOME/$ENV_NAME/bin/activate" ]]; then +                    workon "$ENV_NAME" && export CD_VIRTUAL_ENV="$ENV_NAME" +                fi +            fi +        elif [ $CD_VIRTUAL_ENV ]; then +            # We've just left the repo, deactivate the environment +            # Note: this only happens if the virtualenv was activated automatically +            deactivate && unset CD_VIRTUAL_ENV +        fi +        unset PROJECT_ROOT +    } -    break +    # New cd function that does the virtualenv magic +    function cd { +        builtin cd "$@" && workon_cwd +    }    fi -done - -if [ $WRAPPER_FOUND -eq 0 ] ; then -  print "zsh virtualenvwrapper plugin: Couldn't activate virtualenvwrapper. Please run \`pip install virtualenvwrapper\`." +else +  print "zsh virtualenvwrapper plugin: Cannot find virtualenvwrapper_lazy.sh. Please install with \`pip install virtualenvwrapper\`."  fi | 
