Fixup git-ctags

2016-12-09

author
Meredith Howard <mhoward@roomag.org>
date
Fri, 09 Dec 2016 15:09:08 -0800 (2016-12-09)
changeset 440
aacbd4032a4c
parent 439
f1df55abb64a
child 441
650cbc95b9b0

Fixup git-ctags

.git_helpers/ctags file | annotate | diff | comparison | revisions
.git_helpers/hooks/post-checkout file | annotate | diff | comparison | revisions
.git_helpers/hooks/post-commit file | annotate | diff | comparison | revisions
.git_helpers/hooks/post-merge file | annotate | diff | comparison | revisions
.gitconfig file | annotate | diff | comparison | revisions
bin/git-ctags file | annotate | diff | comparison | revisions
--- a/.git_helpers/hooks/post-checkout
+++ b/.git_helpers/hooks/post-checkout
@@ -2,4 +2,4 @@
 export PATH=/opt/local/bin:${PATH}
 export CTAGS_HOOK=1
 
-~/.git_helpers/ctags >/dev/null 2>&1 </dev/null &
+git ctags >/dev/null 2>&1 </dev/null &
--- a/.git_helpers/hooks/post-commit
+++ b/.git_helpers/hooks/post-commit
@@ -2,4 +2,4 @@
 export PATH=/opt/local/bin:${PATH}
 export CTAGS_HOOK=1
 
-~/.git_helpers/ctags >/dev/null 2>&1 </dev/null &
+git ctags >/dev/null 2>&1 </dev/null &
--- a/.git_helpers/hooks/post-merge
+++ b/.git_helpers/hooks/post-merge
@@ -2,4 +2,4 @@
 export PATH=/opt/local/bin:${PATH}
 export CTAGS_HOOK=1
 
-~/.git_helpers/ctags >/dev/null 2>&1 </dev/null &
+git ctags >/dev/null 2>&1 </dev/null &
--- a/.gitconfig
+++ b/.gitconfig
@@ -28,7 +28,6 @@
 	out     = "!git log --pretty=onelinecustom @{u}.."
 	new     = "!git log --pretty=onelinecustom $1@{1}..$1@{0}"
 	cleanup = "!git branch --merged | grep  -v '\\*\\|master\\|develop' | xargs -n 1 echo git branch -d"
-	ctags   = "!~/.git_helpers/ctags"
 	glog    = log --graph --pretty=onelinecustom
 	recent  = !sh -c 'git for-each-ref --count=${1:-20} --sort=-committerdate --format=\"%(committerdate:short) %(refname:short)\"' "$@"
 
rename from .git_helpers/ctags
rename to bin/git-ctags
--- a/.git_helpers/ctags
+++ b/bin/git-ctags
@@ -1,34 +1,44 @@
 #!/usr/bin/env ruby
 
 # Meant for use as a git hook:
-#   CTAGS_HOOK=1 .git/hooks/ctags &>/dev/null </dev/null &
+#   CTAGS_HOOK=1 ~/.git_helpers/ctags &>/dev/null </dev/null &
 # or an aliased cmd on demand:
 #   git config alias.ctags '!.git/hooks/ctags'
 # or disable when you wish:
 #   CTAGS_SKIP=1 git rebase
 
+# Create a tags file (target) using git's list of tracked files.  If
+# .git/ctags.conf exists in the repo it is passed to the ctags invocation.
+#
+# When run w/o env, immediately run ctags and replace tags file.
+#
+# When run with CTAGS_HOOK, it's assumed to be a BG process and we want to wait
+# for git to be done applying changes no matter how the hook is triggered.
+# Wait five seconds, then bail if we can't get a lock on the tags file or if
+# it's been updated within the last minute. Only then, run ctags and replace
+# the tags file.
+
 exit if ENV['CTAGS_SKIP']
 
-ctags  = "/opt/local/bin/ctags"
-ctags  = 'ctags' if !File.exists?(ctags)
+ctags  = 'ctags'
 
 dir    = `git rev-parse --show-toplevel`.chomp
 
 conf   = "#{dir}/.git/ctags.conf"
 target = "#{dir}/.tags"
-tmp    = "#{dir}/#{$$}.tags"
+tmp    = "#{dir}/.tags.#{$$}~"
 
 opts   = File.exists?(conf) ? "--options=#{conf}" : ''
 
 sleep 5 if ENV['CTAGS_HOOK']
 
-open( target, File::RDONLY|File::CREAT, 0644 ) do |f|
+open(target, File::RDONLY|File::CREAT, 0644) do |f|
   if ENV['CTAGS_HOOK']
-    exit unless f.flock( File::LOCK_EX|File::LOCK_NB )
-    exit unless ( Time.now - f.mtime ) > 60
+    exit unless f.flock(File::LOCK_EX|File::LOCK_NB)
+    exit unless (Time.now - f.mtime) > 60
   end
 
-  system( <<-CMD ) or exit $?.exitstatus
+  system(<<-CMD) or exit $?.exitstatus
     git ls-files \
      | #{ctags} --tag-relative -L - -f"#{tmp}" #{opts} \
     && mv #{tmp} #{target}

mercurial