This is a work in progress and breaking changes to the setup/config could occur in the future. Sorry for any inconveniences.
Git source for hrsh7th/nvim-cmp
Git | Trigger |
---|---|
Commits | : |
GitHub | Trigger |
---|---|
Issues | # |
Mentions (curl only) |
@ |
Pull Requests | # |
GitLab | Trigger |
---|---|
Issues | # |
Mentions | @ |
Merge Requests | ! |
- Neovim >= 0.5.1
- git
- curl
- GitHub CLI (optional, will use curl instead if not avaliable)
- GitLab CLI (unofficial) (optional, will use curl instead if not avaliable)
curl
: Generate token withrepo
scope. SetGITHUB_API_TOKEN
environment variable.GitHub CLI
: Run gh auth login
curl
Generate token withapi
scope. SetGITLAB_TOKEN
environment variable.GitLab CLI
: Run glab auth login
Plug 'nvim-lua/plenary.nvim'
Plug 'petertriho/cmp-git'
use({"petertriho/cmp-git", requires = "nvim-lua/plenary.nvim"})
require("cmp").setup({
sources = {
{ name = "cmp_git" },
-- more sources
}
})
require("cmp_git").setup()
require("cmp_git").setup({
-- defaults
filetypes = { "gitcommit" },
remotes = { "upstream", "origin" }, -- in order of most to least prioritized
enableRemoteUrlRewrites = false, -- enable git url rewrites, see https://git-scm.com/docs/git-config#Documentation/git-config.txt-urlltbasegtinsteadOf
git = {
commits = {
sort_by = function(commit) -- nil, "sha", "title", "description", "author_name", "author_email", "commit_timestamp", or custom function
return string.format("%010d", commit.diff)
end,
limit = 100,
filter_fn = function(trigger_char, commit)
return string.format("%s %s %s", trigger_char, commit.sha, commit.title)
end,
},
},
github = {
issues = {
filter = "all", -- assigned, created, mentioned, subscribed, all, repos
limit = 100,
state = "open", -- open, closed, all
sort_by = function(issue) -- nil, "number", "title", "body", or custom function
return string.format("%010d", os.difftime(os.time(), utils.parse_github_date(issue.updatedAt)))
end,
filter_fn = function(trigger_char, issue)
return string.format("%s %s %s", trigger_char, issue.number, issue.title)
end,
},
mentions = {
limit = 100,
sort_by = nil, -- nil, "login", or custom function
filter_fn = function(trigger_char, mention)
return string.format("%s %s %s", trigger_char, mention.username)
end,
},
pull_requests = {
limit = 100,
state = "open", -- open, closed, merged, all
sort_by = function(pr) -- nil, "number", "title", "body", or custom function
return string.format("%010d", os.difftime(os.time(), utils.parse_github_date(pr.updatedAt)))
end,
filter_fn = function(trigger_char, pr)
return string.format("%s %s %s", trigger_char, pr.number, pr.title)
end,
},
},
gitlab = {
issues = {
limit = 100,
state = "opened", -- opened, closed, all
sort_by = function(issue) -- nil, "iid", "title", "description", or custom function
return string.format("%010d", os.difftime(os.time(), utils.parse_gitlab_date(issue.updated_at)))
end,
filter_fn = function(trigger_char, issue)
return string.format("%s %s %s", trigger_char, issue.iid, issue.title)
end,
},
mentions = {
limit = 100,
sort_by = nil, -- nil, "username", "name", or custom function
filter_fn = function(trigger_char, mention)
return string.format("%s %s", trigger_char, mention.username)
end,
},
merge_requests = {
limit = 100,
state = "opened", -- opened, closed, locked, merged
sort_by = function(mr) -- nil, "iid", "title", "description", or custom function
return string.format("%010d", os.difftime(os.time(), utils.parse_gitlab_date(mr.updated_at)))
end
filter_fn = function(trigger_char, mr)
return string.format("%s %s %s", trigger_char, mr.iid, mr.title)
end,
},
},
trigger_actions = {
{
debug_name = "git_commits",
trigger_character = ":",
action = function(sources, trigger_char, callback, params, git_info)
return sources.git:get_commits(callback, params, trigger_char)
end,
},
{
debug_name = "gitlab_issues",
trigger_character = "#",
action = function(sources, trigger_char, callback, params, git_info)
return sources.gitlab:get_issues(callback, git_info, trigger_char)
end,
},
{
debug_name = "gitlab_mentions",
trigger_character = "@",
action = function(sources, trigger_char, callback, params, git_info)
return sources.gitlab:get_mentions(callback, git_info, trigger_char)
end,
},
{
debug_name = "gitlab_mrs",
trigger_character = "!",
action = function(sources, trigger_char, callback, params, git_info)
return sources.gitlab:get_merge_requests(callback, git_info, trigger_char)
end,
},
{
debug_name = "github_issues_and_pr",
trigger_character = "#",
action = function(sources, trigger_char, callback, params, git_info)
return sources.github:get_issues_and_prs(callback, git_info, trigger_char)
end,
},
{
debug_name = "github_mentions",
trigger_character = "@",
action = function(sources, trigger_char, callback, params, git_info)
return sources.github:get_mentions(callback, git_info, trigger_char)
end,
},
},
}
)
NOTE
If you want specific behaviour for a trigger or new behaviour for a trigger, you need to add
an entry in the trigger_actions
table of the config. The two necessary fields are the trigger_character
and the action
.
Currently, trigger_character
has to be a single character. Multiple actions can be used for the same charachter.
All actions are triggered until one returns true. The parameters to the actions
function are the
different sources (currently git
, gitlab
and github
), the completion callback, the trigger character,
the parameters passed to complete
from nvim-cmp
, and the current git info.
All source functions take an optional config table as last argument, with which the configuration set
in setup
can be overwritten for a specific call.
NOTE on sorting
The default sorting order is last updated (for PRs, MRs and issues) and latest (for commits).
To make nvim-cmp
sort in this order, move cmp.config.compare.sort_text
closer to the top of (lower index) in sorting.comparators
. E.g.
require("cmp").setup({
-- As above
sorting = {
comparators = {
cmp.config.compare.offset,
cmp.config.compare.exact,
cmp.config.compare.sort_text,
cmp.config.compare.score,
cmp.config.compare.recently_used,
cmp.config.compare.kind,
cmp.config.compare.length,
cmp.config.compare.order,
},
},
})
Special thanks to tjdevries for their informative video and starting code.