parent
003f38c6a4
commit
f64ba46509
@ -203,7 +203,7 @@ that are part of Git repositories).
|
|||||||
To use with GitHub FI, point g:fugitive_github_domains
|
To use with GitHub FI, point g:fugitive_github_domains
|
||||||
at a list of domains:
|
at a list of domains:
|
||||||
>
|
>
|
||||||
let g:fugitive_github_domains = ['git.example.com']
|
let g:fugitive_github_domains = ['https://example.com']
|
||||||
~
|
~
|
||||||
:[range]Gbrowse! Like :Gbrowse, but put the URL on the clipboard rather
|
:[range]Gbrowse! Like :Gbrowse, but put the URL on the clipboard rather
|
||||||
than opening it.
|
than opening it.
|
||||||
|
@ -1870,14 +1870,19 @@ endfunction
|
|||||||
function! s:github_url(repo,url,rev,commit,path,type,line1,line2) abort
|
function! s:github_url(repo,url,rev,commit,path,type,line1,line2) abort
|
||||||
let path = a:path
|
let path = a:path
|
||||||
let domain_pattern = 'github\.com'
|
let domain_pattern = 'github\.com'
|
||||||
for domain in exists('g:fugitive_github_domains') ? g:fugitive_github_domains : []
|
let domains = exists('g:fugitive_github_domains') ? g:fugitive_github_domains : []
|
||||||
let domain_pattern .= '\|' . escape(domain, '.')
|
for domain in domains
|
||||||
|
let domain_pattern .= '\|' . escape(split(domain, '://')[-1], '.')
|
||||||
endfor
|
endfor
|
||||||
let repo = matchstr(a:url,'^\%(https\=://\|git://\|git@\)\zs\('.domain_pattern.'\)[/:].\{-\}\ze\%(\.git\)\=$')
|
let repo = matchstr(a:url,'^\%(https\=://\|git://\|git@\)\zs\('.domain_pattern.'\)[/:].\{-\}\ze\%(\.git\)\=$')
|
||||||
if repo ==# ''
|
if repo ==# ''
|
||||||
return ''
|
return ''
|
||||||
endif
|
endif
|
||||||
let root = 'https://' . s:sub(repo,':','/')
|
if index(g:fugitive_github_domains, 'http://' . matchstr(repo, '^[^:/]*')) >= 0
|
||||||
|
let root = 'http://' . s:sub(repo,':','/')
|
||||||
|
else
|
||||||
|
let root = 'https://' . s:sub(repo,':','/')
|
||||||
|
endif
|
||||||
if path =~# '^\.git/refs/heads/'
|
if path =~# '^\.git/refs/heads/'
|
||||||
let branch = a:repo.git_chomp('config','branch.'.path[16:-1].'.merge')[11:-1]
|
let branch = a:repo.git_chomp('config','branch.'.path[16:-1].'.merge')[11:-1]
|
||||||
if branch ==# ''
|
if branch ==# ''
|
||||||
|
Loading…
Reference in New Issue
Block a user