diff options
author | Radoslav Borissov <radoslav.borissov@gmail.com> | 2019-04-19 20:55:05 +0300 |
---|---|---|
committer | Radoslav Borissov <radoslav.borissov@gmail.com> | 2019-04-19 20:55:05 +0300 |
commit | 908cda693f5243a197ccaf5faf5679d0e2ce29a0 (patch) | |
tree | 4116d008758d854a43c443d220a54130a254fb59 /plugin/fugitive-gitea.vim | |
download | fugitive-gitea-908cda693f5243a197ccaf5faf5679d0e2ce29a0.tar.gz fugitive-gitea-908cda693f5243a197ccaf5faf5679d0e2ce29a0.tar.bz2 fugitive-gitea-908cda693f5243a197ccaf5faf5679d0e2ce29a0.zip |
intit.
Diffstat (limited to 'plugin/fugitive-gitea.vim')
-rw-r--r-- | plugin/fugitive-gitea.vim | 65 |
1 files changed, 65 insertions, 0 deletions
diff --git a/plugin/fugitive-gitea.vim b/plugin/fugitive-gitea.vim new file mode 100644 index 0000000..162c139 --- /dev/null +++ b/plugin/fugitive-gitea.vim @@ -0,0 +1,65 @@ +function! s:function(name) abort + return function(substitute(a:name,'^s:',matchstr(expand('<sfile>'), '<SNR>\d\+_'),'')) +endfunction + +function! s:giteaserver_url(opts, ...) abort + if a:0 || type(a:opts) != type({}) + return '' + endif + + let domains = g:fugitive_gitea_domains + let domain_patterns = [] + + for domain in domains + call add(domain_patterns, escape(split(domain, '://')[-1], '.')) + endfor + + let domain_pattern = join(domain_patterns, '\|') + let repo = matchstr(a:opts.remote,'^\%(https\=://\|git://\|\(ssh://\)\=git@\)\%(.\{-\}@\)\=\zs\('.domain_pattern.'\)[/:].\{-\}\ze\%(\.git\)\=$') + if repo ==# '' + return '' + endif + + + if index(domains, 'http://' . matchstr(repo, '^[^:/]*')) >= 0 + let root = 'http://'.repo + else + let root = 'https://'.repo + endif + + let path = substitute(a:opts.path, '^/', '', '') + if path =~# '^\.git/refs/heads/' + return root . '/commits/'.path[16:-1] + elseif path =~# '^\.git/refs/tags/' + return root . '/src/'.path[15:-1] + elseif path =~# '.git/\%(config$\|hooks\>\)' + return root . '/admin' + elseif path =~# '^\.git\>' + return root + endif + if a:opts.commit =~# '^\d\=$' + let commit = a:opts.repo.rev_parse('HEAD') + else + let commit = a:opts.commit + endif + if get(a:opts, 'type', '') ==# 'tree' || a:opts.path =~# '/$' + return '' + elseif get(a:opts, 'type', '') ==# 'blob' || a:opts.path =~# '[^/]$' + let url = root . '/src/commit/'.commit.'/'.path + if get(a:opts, 'line1') + let url .= '\#L' . a:opts.line1 + if get(a:opts, 'line2') != get(a:opts, 'line1') + let url .= '-L' . a:opts.line2 + endif + endif + else + let url = root . '/commit/' . commit + endif + return url +endfunction + +if !exists('g:fugitive_browse_handlers') + let g:fugitive_browse_handlers = [] +endif + +call insert(g:fugitive_browse_handlers, s:function('s:giteaserver_url')) |