feat(nvim): add fuzzy buffer cmp source
This commit is contained in:
parent
16626af0f7
commit
450af04921
@ -17,6 +17,12 @@ return {
|
|||||||
"lukas-reineke/cmp-rg",
|
"lukas-reineke/cmp-rg",
|
||||||
"onsails/lspkind.nvim",
|
"onsails/lspkind.nvim",
|
||||||
"FelipeLema/cmp-async-path",
|
"FelipeLema/cmp-async-path",
|
||||||
|
{
|
||||||
|
"tzachar/cmp-fuzzy-buffer",
|
||||||
|
dependencies = {
|
||||||
|
"tzachar/fuzzy.nvim",
|
||||||
|
}
|
||||||
|
},
|
||||||
-- Snippets
|
-- Snippets
|
||||||
{
|
{
|
||||||
"L3MON4D3/LuaSnip",
|
"L3MON4D3/LuaSnip",
|
||||||
@ -108,11 +114,20 @@ return {
|
|||||||
local default_sources = {
|
local default_sources = {
|
||||||
{ name = "nvim_lsp", priority = 11 },
|
{ name = "nvim_lsp", priority = 11 },
|
||||||
{ name = "luasnip", priority = 10 }, -- For luasnip users.
|
{ name = "luasnip", priority = 10 }, -- For luasnip users.
|
||||||
|
{
|
||||||
|
name = "fuzzy_buffer",
|
||||||
|
priority = 8,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
name = "rg",
|
name = "rg",
|
||||||
priority = 7,
|
priority = 7,
|
||||||
keyword_length = 3,
|
keyword_length = 3,
|
||||||
max_item_count = 10,
|
max_item_count = 10,
|
||||||
|
option = {
|
||||||
|
"--smart-case",
|
||||||
|
"--hidden",
|
||||||
|
"--max-depth 4"
|
||||||
|
}
|
||||||
},
|
},
|
||||||
{ name = "async_path", priority = 6 },
|
{ name = "async_path", priority = 6 },
|
||||||
{ name = "zsh", priority = 5 },
|
{ name = "zsh", priority = 5 },
|
||||||
@ -130,7 +145,6 @@ return {
|
|||||||
---@param entry cmp.Entry
|
---@param entry cmp.Entry
|
||||||
---@param vim_item vim.CompletedItem
|
---@param vim_item vim.CompletedItem
|
||||||
format = function(entry, vim_item)
|
format = function(entry, vim_item)
|
||||||
|
|
||||||
-- vim.notify(vim.inspect(entry))
|
-- vim.notify(vim.inspect(entry))
|
||||||
local selections = {
|
local selections = {
|
||||||
["vim-dadbod-completion"] = { symbol = " ", name = "DB", hl_group = "DadbodCompletion" },
|
["vim-dadbod-completion"] = { symbol = " ", name = "DB", hl_group = "DadbodCompletion" },
|
||||||
@ -141,10 +155,11 @@ return {
|
|||||||
crates = { symbol = " ", name = "Crates", hl_group = "Crates" },
|
crates = { symbol = " ", name = "Crates", hl_group = "Crates" },
|
||||||
cmdline_history = { symbol = " ", name = "Cmd History", hl_group = "CmdHistory" },
|
cmdline_history = { symbol = " ", name = "Cmd History", hl_group = "CmdHistory" },
|
||||||
rg = { symbol = " ", name = "Ripgrep", hl_group = "Ripgrep" },
|
rg = { symbol = " ", name = "Ripgrep", hl_group = "Ripgrep" },
|
||||||
|
fuzzy_buffer = { symbol = " ", name = "Buffer", hl_group = "Buffer" },
|
||||||
npm = { symbol = " ", name = "Npm,", hl_group = "Npm," },
|
npm = { symbol = " ", name = "Npm,", hl_group = "Npm," },
|
||||||
conventionalcommits = { symbol = " ", name = "Commit", hl_group = "Commit" },
|
conventionalcommits = { symbol = " ", name = "Commit", hl_group = "Commit" },
|
||||||
git = { symbol = " ", name = "Git", hl_group = "Git" },
|
git = { symbol = " ", name = "Git", hl_group = "Git" },
|
||||||
docker_compose_language_service = { symbol = " ", name = "Docker", hl_group = "Docker"}
|
docker_compose_language_service = { symbol = " ", name = "Docker", hl_group = "Docker" }
|
||||||
}
|
}
|
||||||
|
|
||||||
local extra_kind_icons = {
|
local extra_kind_icons = {
|
||||||
@ -308,7 +323,9 @@ return {
|
|||||||
},
|
},
|
||||||
sources = standard_sources(),
|
sources = standard_sources(),
|
||||||
sorting = {
|
sorting = {
|
||||||
|
priority_weight = 2,
|
||||||
comparators = {
|
comparators = {
|
||||||
|
require('cmp_fuzzy_buffer.compare'),
|
||||||
compare.score,
|
compare.score,
|
||||||
compare.offset,
|
compare.offset,
|
||||||
compare.recently_used,
|
compare.recently_used,
|
||||||
@ -335,16 +352,22 @@ return {
|
|||||||
}),
|
}),
|
||||||
})
|
})
|
||||||
|
|
||||||
cmp.setup.filetype("sql", { sources = standard_sources({ { name = "vim-dadbod-completion", priority = 99 } }) })
|
cmp.setup.filetype("sql",
|
||||||
cmp.setup.filetype("mysql", { sources = standard_sources({ { name = "vim-dadbod-completion", priority = 99 } }) })
|
{ sources = standard_sources({ { name = "vim-dadbod-completion", priority = 99 } }) })
|
||||||
cmp.setup.filetype("plsql", { sources = standard_sources({ { name = "vim-dadbod-completion", priority = 99 } }) })
|
cmp.setup.filetype("mysql",
|
||||||
|
{ sources = standard_sources({ { name = "vim-dadbod-completion", priority = 99 } }) })
|
||||||
|
cmp.setup.filetype("plsql",
|
||||||
|
{ sources = standard_sources({ { name = "vim-dadbod-completion", priority = 99 } }) })
|
||||||
cmp.setup.filetype("toml", { sources = standard_sources({ { name = "crates" } }) })
|
cmp.setup.filetype("toml", { sources = standard_sources({ { name = "crates" } }) })
|
||||||
cmp.setup.filetype("org", { sources = standard_sources({ { name = "orgmode", priority = 99 } }) })
|
cmp.setup.filetype("org", { sources = standard_sources({ { name = "orgmode", priority = 99 } }) })
|
||||||
|
|
||||||
-- Use buffer source for `/` (if you enabled `native_menu`, this won't work anymore).
|
-- Use buffer source for `/` (if you enabled `native_menu`, this won't work anymore).
|
||||||
cmp.setup.cmdline("/", {
|
cmp.setup.cmdline("/", {
|
||||||
mapping = cmp.mapping.preset.cmdline(),
|
mapping = cmp.mapping.preset.cmdline(),
|
||||||
sources = cmp.config.sources({ { name = "rg" } }),
|
sources = cmp.config.sources({
|
||||||
|
{ name = "fuzzy_buffer" },
|
||||||
|
{ name = "rg" }
|
||||||
|
}),
|
||||||
})
|
})
|
||||||
|
|
||||||
cmp.setup.cmdline("?", {
|
cmp.setup.cmdline("?", {
|
||||||
@ -371,6 +394,7 @@ return {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
{ name = "cmdline_history", max_item_count = 3 },
|
{ name = "cmdline_history", max_item_count = 3 },
|
||||||
|
{ name = "fuzzy_buffer" },
|
||||||
{ name = "rg" },
|
{ name = "rg" },
|
||||||
}),
|
}),
|
||||||
})
|
})
|
||||||
|
@ -109,7 +109,7 @@ return {
|
|||||||
CmpCustomSelectionColor = { bg = colors.sumiInk5 },
|
CmpCustomSelectionColor = { bg = colors.sumiInk5 },
|
||||||
CmpCustomSelectionDadbodCompletion = { fg = colors.fujiWhite, bg = colors.oniViolet },
|
CmpCustomSelectionDadbodCompletion = { fg = colors.fujiWhite, bg = colors.oniViolet },
|
||||||
CmpCustomSelectionGit = { fg = colors.fujiWhite, bg = colors.roninYellow },
|
CmpCustomSelectionGit = { fg = colors.fujiWhite, bg = colors.roninYellow },
|
||||||
CmpCustomSelectionBuffer = { fg = colors.fujiWhite, bg = colors.dragonBlue },
|
CmpCustomSelectionBuffer = { fg = colors.fujiWhite, bg = colors.springBlue },
|
||||||
CmpCustomSelectionPath = { fg = colors.fujiWhite, bg = colors.autumnYellow },
|
CmpCustomSelectionPath = { fg = colors.fujiWhite, bg = colors.autumnYellow },
|
||||||
CmpCustomSelectionCalculator = { fg = colors.fujiWhite, bg = colors.waveBlue2 },
|
CmpCustomSelectionCalculator = { fg = colors.fujiWhite, bg = colors.waveBlue2 },
|
||||||
CmpCustomSelectionOrgmode = { fg = colors.fujiWhite, bg = colors.waveAqua1 },
|
CmpCustomSelectionOrgmode = { fg = colors.fujiWhite, bg = colors.waveAqua1 },
|
||||||
@ -118,7 +118,7 @@ return {
|
|||||||
CmpCustomSelectionCrates = { fg = colors.fujiWhite, bg = colors.roninYellow },
|
CmpCustomSelectionCrates = { fg = colors.fujiWhite, bg = colors.roninYellow },
|
||||||
CmpCustomSelectionDocker = { fg = colors.fujiWhite, bg = colors.springBlue },
|
CmpCustomSelectionDocker = { fg = colors.fujiWhite, bg = colors.springBlue },
|
||||||
CmpCustomSelectionCmdHistory = { fg = colors.fujiWhite, bg = colors.waveBlue2 },
|
CmpCustomSelectionCmdHistory = { fg = colors.fujiWhite, bg = colors.waveBlue2 },
|
||||||
CmpCustomSelectionRipgrep = { fg = colors.fujiWhite, bg = colors.dragonBlue },
|
CmpCustomSelectionRipgrep = { fg = colors.fujiWhite, bg = colors.crystalBlue },
|
||||||
CmpCustomSelectionNpm = { fg = colors.fujiWhite, bg = colors.peachRed },
|
CmpCustomSelectionNpm = { fg = colors.fujiWhite, bg = colors.peachRed },
|
||||||
CmpCustomSelectionCommit = { fg = colors.fujiWhite, bg = colors.peachRed },
|
CmpCustomSelectionCommit = { fg = colors.fujiWhite, bg = colors.peachRed },
|
||||||
TelescopeNormal = { bg = colors.sumiInk2 },
|
TelescopeNormal = { bg = colors.sumiInk2 },
|
||||||
|
Loading…
Reference in New Issue
Block a user