diff options
| -rw-r--r-- | bundle/github-url/autoload/github_url.vim | 35 | ||||
| -rw-r--r-- | bundle/github-url/plugin/github_url.vim | 37 | 
2 files changed, 40 insertions, 32 deletions
| diff --git a/bundle/github-url/autoload/github_url.vim b/bundle/github-url/autoload/github_url.vim new file mode 100644 index 0000000..11110a8 --- /dev/null +++ b/bundle/github-url/autoload/github_url.vim @@ -0,0 +1,35 @@ +" Constructs a GitHub URL for the current Git repo by making substitutions to +" the SSH location to turn it into an HTTP URL. +function! s:BaseRepoURL() +	let remote = system('git remote get-url origin') +	let base_url = substitute(remote, ':', '/', '') +	let base_url = substitute(base_url, '^git@', 'https://', '') +	let base_url = substitute(base_url, '.git\n$', '', '') + +	return base_url +endfunction + +" Constructs a GitHub URL to the current file using the current HEAD's SHA. If +" lines are passed in, these are included in the URL. The `include_lines` +" argument comes from a `:command`'s `<count>`, and tells the function whether +" a range was given. +function! s:FileURL(include_lines, start_line, end_line) +	let current_sha = system('git show --format="format:%H"') +	let current_sha = substitute(current_sha, '\n$', '', '') +	let current_filename = expand('%') +	let lines = '' + +	if a:include_lines +		let lines = '#L' . a:start_line + +		if a:start_line != a:end_line +			let lines = lines . '-L' . a:end_line +		endif +	endif + +	return s:BaseRepoURL() . '/blob/' . current_sha . '/' . current_filename . lines +endfunction + +function! github_url#GitHubURL(include_lines, start_line, end_line) +	return s:FileURL(a:include_lines, a:start_line, a:end_line) +endfunction diff --git a/bundle/github-url/plugin/github_url.vim b/bundle/github-url/plugin/github_url.vim index 96483cb..84f6cce 100644 --- a/bundle/github-url/plugin/github_url.vim +++ b/bundle/github-url/plugin/github_url.vim @@ -1,33 +1,6 @@ -" Constructs a GitHub URL for the current Git repo by making substitutions to -" the SSH location to turn it into an HTTP URL. -function! s:BaseRepoURL() -	let remote = system('git remote get-url origin') -	let base_url = substitute(remote, ':', '/', '') -	let base_url = substitute(base_url, '^git@', 'https://', '') -	let base_url = substitute(base_url, '.git\n$', '', '') +if exists('g:loaded_github_url') +	finish +endif +let g:loaded_github_url = 1 -	return base_url -endfunction - -" Constructs a GitHub URL to the current file using the current HEAD's SHA. If -" lines are passed in, these are included in the URL. The `include_lines` -" argument comes from a `:command`'s `<count>`, and tells the function whether -" a range was given. -function! s:FileURL(include_lines, start_line, end_line) -	let current_sha = system('git show --format="format:%H"') -	let current_sha = substitute(current_sha, '\n$', '', '') -	let current_filename = expand('%') -	let lines = '' - -	if a:include_lines -		let lines = '#L' . a:start_line - -		if a:start_line != a:end_line -			let lines = lines . '-L' . a:end_line -		endif -	endif - -	return s:BaseRepoURL() . '/blob/' . current_sha . '/' . current_filename . lines -endfunction - -command! -range=0 GitHubFileURL :echo <SID>FileURL(<count>, <line1>, <line2>) +command! -range=0 GitHubFileURL :echo github_url#GitHubURL(<count>, <line1>, <line2>) | 
