This commit is contained in:
GitHub Merge Button 2012-07-18 18:44:04 -07:00
commit ea23b78757
3 changed files with 39 additions and 22 deletions

View file

@ -4,6 +4,10 @@ function git_prompt_info() {
echo "$ZSH_THEME_GIT_PROMPT_PREFIX${ref#refs/heads/}$(parse_git_dirty)$ZSH_THEME_GIT_PROMPT_SUFFIX" echo "$ZSH_THEME_GIT_PROMPT_PREFIX${ref#refs/heads/}$(parse_git_dirty)$ZSH_THEME_GIT_PROMPT_SUFFIX"
} }
# returns root of current repo
function git_get_root() {
echo "$(git rev-parse --show-toplevel 2> /dev/null)"
}
# Checks if working tree is dirty # Checks if working tree is dirty
parse_git_dirty() { parse_git_dirty() {
@ -71,7 +75,7 @@ git_prompt_status() {
#compare the provided version of git to the version installed and on path #compare the provided version of git to the version installed and on path
#prints 1 if input version <= installed version #prints 1 if input version <= installed version
#prints -1 otherwise #prints -1 otherwise
function git_compare_version() { function git_compare_version() {
local INPUT_GIT_VERSION=$1; local INPUT_GIT_VERSION=$1;
local INSTALLED_GIT_VERSION local INSTALLED_GIT_VERSION

View file

@ -60,6 +60,11 @@ function current_repository() {
echo $(git remote -v | cut -d':' -f 2) echo $(git remote -v | cut -d':' -f 2)
} }
# change workdir to repo's root (or do `cd` with no arguments if not in a repo)
function toroot() {
builtin cd "`git_get_root`"
}
# these aliases take advantage of the previous function # these aliases take advantage of the previous function
alias ggpull='git pull origin $(current_branch)' alias ggpull='git pull origin $(current_branch)'
compdef ggpull=git compdef ggpull=git

View file

@ -8,32 +8,38 @@ for wrapsource in "/usr/bin/virtualenvwrapper.sh" "/usr/local/bin/virtualenvwrap
# Automatically activate Git projects' virtual environments based on the # Automatically activate Git projects' virtual environments based on the
# directory name of the project. Virtual environment name can be overridden # 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 # by placing a .venv file in the project root with a virtualenv name in it
function workon_cwd { function _workon_cwd {
# Check that this is a Git repo # Check that this is a Git repo and get its root
PROJECT_ROOT=`git rev-parse --show-toplevel 2> /dev/null` local repo_root=`git_get_root`
if (( $? == 0 )); then if [[ -n "$repo_root" ]]; then
# Check for virtualenv name override local env_name=`basename "$repo_root"`
ENV_NAME=`basename "$PROJECT_ROOT"` if [[ -f "$repo_root/.venv" ]]; then
if [[ -f "$PROJECT_ROOT/.venv" ]]; then env_name=`cat "$repo_root/.venv"`
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 fi
unset PROJECT_ROOT # 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"
else
_deactivate
fi
fi
else
# We've just left the repo, deactivate the environment
# Note: this only happens if the virtualenv was activated automatically
_deactivate
fi
}
function _deactivate() {
if [[ -n $CD_VIRTUAL_ENV ]]; then
deactivate && unset CD_VIRTUAL_ENV
fi
} }
# New cd function that does the virtualenv magic # New cd function that does the virtualenv magic
function cd { function cd {
builtin cd "$@" && workon_cwd builtin cd "$@" && _workon_cwd
} }
fi fi
@ -44,3 +50,5 @@ done
if [ $WRAPPER_FOUND -eq 0 ] ; then if [ $WRAPPER_FOUND -eq 0 ] ; then
print "zsh virtualenvwrapper plugin: Couldn't activate virtualenvwrapper. Please run \`pip install virtualenvwrapper\`." print "zsh virtualenvwrapper plugin: Couldn't activate virtualenvwrapper. Please run \`pip install virtualenvwrapper\`."
fi fi
unset WRAPPER_FOUND