]> git.madduck.net Git - etc/zsh.git/blobdiff - .zsh/zshrc/85_vcs_prompt

madduck's git repository

Every one of the projects in this repository is available at the canonical URL git://git.madduck.net/madduck/pub/<projectpath> — see each project's metadata for the exact URL.

All patches and comments are welcome. Please squash your changes to logical commits before using git-format-patch and git-send-email to patches@git.madduck.net. If you'd read over the Git project's submission guidelines and adhered to them, I'd be especially grateful.

SSH access, as well as push access can be individually arranged.

If you use my repositories frequently, consider adding the following snippet to ~/.gitconfig and using the third clone URL listed for each project:

[url "git://git.madduck.net/madduck/"]
  insteadOf = madduck:

Add warnings for unsupported repo types
[etc/zsh.git] / .zsh / zshrc / 85_vcs_prompt
index 63ccb6517abb2440038af2b5d2711f39156edcff..814fed8dcacd457b7588bc224e25ec3a11569d55 100644 (file)
@@ -52,19 +52,24 @@ __get_prompt_path_components()
 
 __vcs_get_repo_type()
 {
-  if __git_get_repo_root >/dev/null; then
-    echo git
-  else
-    echo NONE
-  fi
+  while true; do
+    [ -d .git ] && echo git && break
+    [ -d .bzr ] && echo bzr && break
+    [ -d .hg ] && echo hg && break
+    [ -d .svn ] && echo svn && break
+    [ -d CVS ] && echo cvs && break
+    [ "$PWD" = / ] && echo NONE && return 1
+    cd ..
+  done
 }
 
 __vcs_set_prompt_variables()
 {
   local pre branch post
   local MAXLEN=25
+  local repotype="${1:-$(__vcs_get_repo_type)}"
 
-  case "${1:-$(__vcs_get_repo_type)}" in
+  case "$repotype" in
     git)
       local reporoot="$(__git_get_repo_root)"
       set -- $(__get_prompt_path_components "$reporoot")
@@ -76,6 +81,10 @@ __vcs_set_prompt_variables()
       pre="${(%)pre}"
       ;;
     *)
+      case "$repotype" in
+        NONE) :;;
+        *) warn "$repotype repositories not (yet) supported in the prompt";;
+      esac
       local p="%${MAXLEN}<..<%~%<<"
       #TODO find a better way so we don't have to nuke $psvar, but since the
       #     %(nv.true.false) check for prompts checks element count, not
@@ -99,15 +108,15 @@ if ! is_root; then
       *${vcs}*) __vcs_set_prompt_variables
     esac
   }
-  precmd_functions+=_update_vcs prompt_vars_if_vcs_ran
+  precmd_functions+=_update_vcs_prompt_vars_if_vcs_ran
 
   _update_vcs_prompt_vars() {
     __vcs_set_prompt_variables
   }
   chpwd_functions+=_update_vcs_prompt_vars
-fi
 
-# call it once
-_update_vcs_prompt_vars
+  # call it once
+  _update_vcs_prompt_vars
+fi
 
 # vim:ft=zsh