about summary refs log tree commit diff
path: root/Misc
diff options
context:
space:
mode:
authorFrank Terbeck <bewater@users.sourceforge.net>2011-06-01 21:21:04 +0000
committerFrank Terbeck <bewater@users.sourceforge.net>2011-06-01 21:21:04 +0000
commit0deff4f99aaf2e6389ab441eec04c68a9a27681d (patch)
treeb004f9ee6534da765b77dfde81e0069bf91cd696 /Misc
parent0cc65dba531a792db26592a4e9c1efe5f9f667bd (diff)
downloadzsh-0deff4f99aaf2e6389ab441eec04c68a9a27681d.tar.gz
zsh-0deff4f99aaf2e6389ab441eec04c68a9a27681d.tar.xz
zsh-0deff4f99aaf2e6389ab441eec04c68a9a27681d.zip
Valentin Haenel: 29431: Hook example for signaling untracked files in git repositories
Diffstat (limited to 'Misc')
-rw-r--r--Misc/vcs_info-examples17
1 files changed, 17 insertions, 0 deletions
diff --git a/Misc/vcs_info-examples b/Misc/vcs_info-examples
index bc10a2179..860297c9e 100644
--- a/Misc/vcs_info-examples
+++ b/Misc/vcs_info-examples
@@ -155,6 +155,23 @@ function +vi-hg-shorthash() {
     ret=1
 }
 
+### Display the existence of files not yet known to VCS
+
+### git: Show marker (T) if there are untracked files in repository
+# Make sure you have added staged to your 'formats':  %c
+zstyle ':vcs_info:git*+set-message:*' hooks git-untracked
+
++vi-git-untracked(){
+    if [[ $(git rev-parse --is-inside-work-tree 2> /dev/null) == 'true' ]] && \
+        git status --porcelain | grep '??' &> /dev/null ; then
+        # This will show the marker if there are any untracked files in repo.
+        # If instead you want to show the marker only if there are untracked
+        # files in $PWD, use:
+        #[[ -n $(git ls-files --others --exclude-standard) ]] ; then
+        hook_com[staged]+='T'
+    fi
+}
+
 
 ### Compare local changes to remote changes