diff options
author | Teddy Wing | 2017-04-29 04:48:35 +0200 |
---|---|---|
committer | Teddy Wing | 2017-04-29 04:48:35 +0200 |
commit | ee60b16343ff5e98dc4279bb976586001a002bfe (patch) | |
tree | cd8e1d232af2ea82d6424305d5566ee9cfd1323d /autoload/gitcha.vim | |
parent | bc4fcb2b082805914d6e87ff38516dbafc5c5538 (diff) | |
download | vim-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.vim | 32 |
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 |