aboutsummaryrefslogtreecommitdiffstats
path: root/autoload/gitcha.vim
diff options
context:
space:
mode:
authorTeddy Wing2017-04-29 04:48:35 +0200
committerTeddy Wing2017-04-29 04:48:35 +0200
commitee60b16343ff5e98dc4279bb976586001a002bfe (patch)
treecd8e1d232af2ea82d6424305d5566ee9cfd1323d /autoload/gitcha.vim
parentbc4fcb2b082805914d6e87ff38516dbafc5c5538 (diff)
downloadvim-gitcha-ee60b16343ff5e98dc4279bb976586001a002bfe.tar.bz2
Move functions to autoload/
Don't force our functions to be loaded when the ftplugin is loaded. Be good Vimscript citizens and respect load performance.
Diffstat (limited to 'autoload/gitcha.vim')
-rw-r--r--autoload/gitcha.vim32
1 files changed, 32 insertions, 0 deletions
diff --git a/autoload/gitcha.vim b/autoload/gitcha.vim
new file mode 100644
index 0000000..6defd61
--- /dev/null
+++ b/autoload/gitcha.vim
@@ -0,0 +1,32 @@
+let s:old_completefunc = &completefunc
+
+function! gitcha#GitSHAComplete(findstart, base)
+ if a:findstart
+ " locate the start of the word
+ let line = getline('.')
+ let start = col('.') - 1
+ while start > 0 && line[start - 1] =~ '\a'
+ let start -= 1
+ endwhile
+ return start
+ endif
+
+ " Restore user completion function
+ let &completefunc = s:old_completefunc
+
+ " Match Git SHAs in the current repository
+ let matches = []
+ let revs = system('git rev-list --all')
+ for m in split(revs)
+ if m =~ '^' . a:base
+ call add(matches, m)
+ endif
+ endfor
+
+ return matches
+endfunction
+
+function! gitcha#StartGitSHACompletion()
+ set completefunc=gitcha#GitSHAComplete
+ return "\<C-x>\<C-u>"
+endfunction