virtualenvwrapper.plugin.zsh 1.59 KB
Newer Older
1
wrapsource=`which virtualenvwrapper_lazy.sh`
2

3
4
if [[ -f "$wrapsource" ]]; then
  source $wrapsource
5

6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
  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
    }
32

33
34
35
36
    # New cd function that does the virtualenv magic
    function cd {
        builtin cd "$@" && workon_cwd
    }
37
  fi
38
else
39
  print "zsh virtualenvwrapper plugin: Cannot find virtualenvwrapper_lazy.sh. Please install with \`pip install virtualenvwrapper\`."
40
fi