From 085d21617daeee004c118da2c41cedf551a5f7fc Mon Sep 17 00:00:00 2001 From: Chen Houwu Date: Sat, 4 Jan 2014 18:34:27 +0800 Subject: [PATCH] add nodeenv --- plugins/{nodeenv-prompt => nodeenv}/README.md | 0 .../nodeenv-prompt.plugin.zsh | 0 plugins/nodeenv/nodeenv.plugin.zsh | 49 +++++++++++++++++++ 3 files changed, 49 insertions(+) rename plugins/{nodeenv-prompt => nodeenv}/README.md (100%) rename plugins/{nodeenv-prompt => nodeenv}/nodeenv-prompt.plugin.zsh (100%) create mode 100644 plugins/nodeenv/nodeenv.plugin.zsh diff --git a/plugins/nodeenv-prompt/README.md b/plugins/nodeenv/README.md similarity index 100% rename from plugins/nodeenv-prompt/README.md rename to plugins/nodeenv/README.md diff --git a/plugins/nodeenv-prompt/nodeenv-prompt.plugin.zsh b/plugins/nodeenv/nodeenv-prompt.plugin.zsh similarity index 100% rename from plugins/nodeenv-prompt/nodeenv-prompt.plugin.zsh rename to plugins/nodeenv/nodeenv-prompt.plugin.zsh diff --git a/plugins/nodeenv/nodeenv.plugin.zsh b/plugins/nodeenv/nodeenv.plugin.zsh new file mode 100644 index 000000000..49b860e0a --- /dev/null +++ b/plugins/nodeenv/nodeenv.plugin.zsh @@ -0,0 +1,49 @@ +if [[ ! $DISABLE_NODEENV_CD -eq 1 ]]; then + # Automatically activate Git projects's virtual environments based on the + # directory name of the project. Virtual environment name can be overridden + # by placing a .nodeenv file in the project root with a virtualenv name in it + function nodeenv_cwd { + if [ ! $NODEENV_CWD ]; then + NODEENV_CWD=1 + # Check if this is a Git repo + NODEENV_PROJECT_ROOT=`git rev-parse --show-toplevel 2> /dev/null` + if (( $? != 0 )); then + NODEENV_PROJECT_ROOT="." + fi + # Check for virtualenv name override + if [[ -f "$NODEENV_PROJECT_ROOT/.nodeenv" ]]; then + NODEENV_NAME=`cat "$NODEENV_PROJECT_ROOT/.nodeenv"` + elif [[ -f "$NODEENV_PROJECT_ROOT/.nodeenv/bin/activate" ]];then + NODEENV_NAME="$NODEENV_PROJECT_ROOT/.nodeenv" + elif [[ "$NODEENV_PROJECT_ROOT" != "." ]]; then + NODEENV_NAME=`basename "$NODEENV_PROJECT_ROOT"` + else + NODEENV_NAME="" + fi + source $NODEENV_NAME/bin/activate && export CD_NODEENV="$NODEENV_NAME" + if [[ "$NODEENV_NAME" != "" ]]; then + # Activate the environment only if it is not already active + if [[ "$NODE_VIRTUAL_ENV" != "$WORKON_HOME/$NODEENV_NAME" ]]; then + source $NODEENV_NAME/bin/activate && export CD_NODEENV="$NODEENV_NAME" + fi + elif [ $CD_NODEENV ]; then + # We've just left the repo, deactivate the environment + # Note: this only happens if the virtualenv was activated automatically + deactivate_node && unset CD_NODEENV + fi + unset NODEENV_PROJECT_ROOT + unset NODEENV_CWD + fi + } + + # Append workon_cwd to the chpwd_functions array, so it will be called on cd + # http://zsh.sourceforge.net/Doc/Release/Functions.html + # TODO: replace with 'add-zsh-hook chpwd workon_cwd' when oh-my-zsh min version is raised above 4.3.4 + if (( ${+chpwd_functions} )); then + if (( $chpwd_functions[(I)nodeenv_cwd] == 0 )); then + set -A chpwd_functions $chpwd_functions nodeenv_cwd + fi + else + set -A chpwd_functions nodeenv_cwd + fi +fi