Control priority by bang
This commit is contained in:
parent
27655e19d4
commit
2388e69546
2 changed files with 16 additions and 17 deletions
|
|
@ -22,7 +22,7 @@ function M.setup()
|
||||||
M.repo_url = string.format("http://%s/%s/%s", gh.host, gh.user_or_org, gh.reponame)
|
M.repo_url = string.format("http://%s/%s/%s", gh.host, gh.user_or_org, gh.reponame)
|
||||||
end
|
end
|
||||||
|
|
||||||
M.priority = { BRANCH = 'branch-priority', COMMIT = 'commit-priority', }
|
M.priority = { BRANCH = 1, COMMIT = 2, }
|
||||||
|
|
||||||
local function get_current_branch_or_commit_with_priority(priority)
|
local function get_current_branch_or_commit_with_priority(priority)
|
||||||
if priority == M.priority.BRANCH then
|
if priority == M.priority.BRANCH then
|
||||||
|
|
|
||||||
|
|
@ -5,20 +5,22 @@ vim.g.openingh = true
|
||||||
|
|
||||||
local openingh = require("openingh")
|
local openingh = require("openingh")
|
||||||
|
|
||||||
local complete_list = { openingh.priority.BRANCH, openingh.priority.COMMIT, }
|
local function judge_priority(bang)
|
||||||
local function complete_func(arg_lead, _, _)
|
-- When the command executed with bang `!`, prioritizes commit rather than branch.
|
||||||
return vim.tbl_filter(function(item)
|
if bang then
|
||||||
return vim.startswith(item, arg_lead)
|
return openingh.priority.COMMIT
|
||||||
end, complete_list)
|
else
|
||||||
|
return openingh.priority.BRANCH
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
vim.api.nvim_create_user_command("OpenInGHFile", function(opts)
|
vim.api.nvim_create_user_command("OpenInGHFile", function(opts)
|
||||||
local url
|
local url
|
||||||
|
|
||||||
if opts.range == 0 then -- Nothing was selected
|
if opts.range == 0 then -- Nothing was selected
|
||||||
url = openingh.get_file_url(opts.args)
|
url = openingh.get_file_url(judge_priority(opts.bang))
|
||||||
else -- Current line or block was selected
|
else -- Current line or block was selected
|
||||||
url = openingh.get_file_url(opts.args, opts.line1, opts.line2)
|
url = openingh.get_file_url(judge_priority(opts.bang), opts.line1, opts.line2)
|
||||||
end
|
end
|
||||||
|
|
||||||
if opts.reg == "" then
|
if opts.reg == "" then
|
||||||
|
|
@ -30,17 +32,16 @@ vim.api.nvim_create_user_command("OpenInGHFile", function(opts)
|
||||||
end, {
|
end, {
|
||||||
register = true,
|
register = true,
|
||||||
range = true,
|
range = true,
|
||||||
nargs = '?',
|
bang = true,
|
||||||
complete = complete_func,
|
|
||||||
})
|
})
|
||||||
|
|
||||||
vim.api.nvim_create_user_command("OpenInGHFileLines", function(opts)
|
vim.api.nvim_create_user_command("OpenInGHFileLines", function(opts)
|
||||||
local url
|
local url
|
||||||
|
|
||||||
if opts.range == 0 then -- Nothing was selected
|
if opts.range == 0 then -- Nothing was selected
|
||||||
url = openingh.get_file_url(opts.args, opts.line1)
|
url = openingh.get_file_url(judge_priority(opts.bang), opts.line1)
|
||||||
else -- Current line or block was selected
|
else -- Current line or block was selected
|
||||||
url = openingh.get_file_url(opts.args, opts.line1, opts.line2)
|
url = openingh.get_file_url(judge_priority(opts.bang), opts.line1, opts.line2)
|
||||||
end
|
end
|
||||||
|
|
||||||
if opts.reg == "" then
|
if opts.reg == "" then
|
||||||
|
|
@ -52,12 +53,11 @@ vim.api.nvim_create_user_command("OpenInGHFileLines", function(opts)
|
||||||
end, {
|
end, {
|
||||||
register = true,
|
register = true,
|
||||||
range = true,
|
range = true,
|
||||||
nargs = '?',
|
bang = true,
|
||||||
complete = complete_func,
|
|
||||||
})
|
})
|
||||||
|
|
||||||
vim.api.nvim_create_user_command("OpenInGHRepo", function(opts)
|
vim.api.nvim_create_user_command("OpenInGHRepo", function(opts)
|
||||||
local url = openingh.get_repo_url(opts.args)
|
local url = openingh.get_repo_url(judge_priority(opts.bang))
|
||||||
|
|
||||||
if opts.reg == "" then
|
if opts.reg == "" then
|
||||||
openingh.open_url(url)
|
openingh.open_url(url)
|
||||||
|
|
@ -67,6 +67,5 @@ vim.api.nvim_create_user_command("OpenInGHRepo", function(opts)
|
||||||
end
|
end
|
||||||
end, {
|
end, {
|
||||||
register = true,
|
register = true,
|
||||||
nargs = '?',
|
bang = true,
|
||||||
complete = complete_func,
|
|
||||||
})
|
})
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue