This commit is contained in:
ksyasuda@umich.edu 2023-09-06 16:22:30 -07:00
parent d34b2da189
commit cbf5a51890

View File

@ -18,9 +18,9 @@ local has_words_before = function()
"^%s*$") == nil "^%s*$") == nil
end end
lspkind.init({symbol_map = {Copilot = ""}}) lspkind.init({ symbol_map = { Copilot = "" } })
vim.api.nvim_set_hl(0, "CmpItemKindCopilot", {fg = "#6CC644"}) vim.api.nvim_set_hl(0, "CmpItemKindCopilot", { fg = "#6CC644" })
cmp.setup({ cmp.setup({
snippet = { snippet = {
@ -43,7 +43,7 @@ cmp.setup({
else else
fallback() fallback()
end end
end, {'i', 's'}), end, { 'i', 's' }),
['<C-n>'] = cmp.mapping(function(fallback) ['<C-n>'] = cmp.mapping(function(fallback)
if cmp.visible() then if cmp.visible() then
cmp.select_next_item() cmp.select_next_item()
@ -54,7 +54,7 @@ cmp.setup({
else else
fallback() fallback()
end end
end, {'i', 's'}), end, { 'i', 's' }),
['<C-d>'] = cmp.mapping.scroll_docs(-4), ['<C-d>'] = cmp.mapping.scroll_docs(-4),
['<C-f>'] = cmp.mapping.scroll_docs(4), ['<C-f>'] = cmp.mapping.scroll_docs(4),
['<C-Space>'] = cmp.mapping.complete(), ['<C-Space>'] = cmp.mapping.complete(),
@ -74,7 +74,7 @@ cmp.setup({
-- end, { "i", "s" }), -- end, { "i", "s" }),
["<Tab>"] = vim.schedule_wrap(function(fallback) ["<Tab>"] = vim.schedule_wrap(function(fallback)
if cmp.visible() and has_words_before() then if cmp.visible() and has_words_before() then
cmp.select_next_item({behavior = cmp.SelectBehavior.Select}) cmp.select_next_item({ behavior = cmp.SelectBehavior.Select })
elseif luasnip.expand_or_jumpable() then elseif luasnip.expand_or_jumpable() then
luasnip.expand_or_jump() luasnip.expand_or_jump()
else else
@ -83,7 +83,7 @@ cmp.setup({
end), end),
['<S-Tab>'] = cmp.mapping(function() ['<S-Tab>'] = cmp.mapping(function()
if cmp.visible() then cmp.select_prev_item() end if cmp.visible() then cmp.select_prev_item() end
end, {"i", "s"}) end, { "i", "s" })
}, },
window = { window = {
completion = { completion = {
@ -106,7 +106,7 @@ cmp.setup({
formatting = { formatting = {
-- options: 'text', 'text_symbol', 'symbol_text', 'symbol' -- options: 'text', 'text_symbol', 'symbol_text', 'symbol'
-- mode = 'symbol_text', -- mode = 'symbol_text',
fields = {"kind", "abbr", "menu"}, fields = { "kind", "abbr", "menu" },
format = function(entry, vim_item) format = function(entry, vim_item)
local kind = require("lspkind").cmp_format({ local kind = require("lspkind").cmp_format({
mode = "symbol_text", mode = "symbol_text",
@ -139,7 +139,7 @@ cmp.setup({
TypeParameter = "󰅲" TypeParameter = "󰅲"
} }
})(entry, vim_item) })(entry, vim_item)
local strings = vim.split(kind.kind, "%s", {trimempty = true}) local strings = vim.split(kind.kind, "%s", { trimempty = true })
kind.kind = " " .. strings[1] .. " " kind.kind = " " .. strings[1] .. " "
kind.menu = " (" .. strings[2] .. ")" kind.menu = " (" .. strings[2] .. ")"
@ -157,13 +157,13 @@ cmp.setup({
-- }) -- })
}, },
sources = cmp.config.sources({ sources = cmp.config.sources({
{name = "copilot", group_index = 2}, {name = "path", group_index = 2}, { name = "copilot", group_index = 2 }, { name = "path", group_index = 2 },
{name = 'nvim_lsp', group_index = 2}, { name = 'nvim_lsp', group_index = 2 },
{name = 'nvim_lsp_signature_help', group_index = 2}, { name = 'nvim_lsp_signature_help', group_index = 2 },
{name = 'nvim_lsp_document_symbol', group_index = 2}, { name = 'nvim_lsp_document_symbol', group_index = 2 },
{name = 'vim-dadbod-completion', group_index = 2}, { name = 'vim-dadbod-completion', group_index = 2 },
{name = 'neorg', group_index = 2}, -- For luasnip users. { name = 'neorg', group_index = 2 }, -- For luasnip users.
{name = 'luasnip', group_index = 2}, -- For luasnip users. { name = 'luasnip', group_index = 2 }, -- For luasnip users.
{ {
name = 'buffer', name = 'buffer',
option = { option = {
@ -178,7 +178,7 @@ cmp.setup({
} }
-- { name = 'ultisnips' }, -- For ultisnips users. -- { name = 'ultisnips' }, -- For ultisnips users.
-- { name = 'snippy' }, -- For snippy users. -- { name = 'snippy' }, -- For snippy users.
}, {{name = 'buffer'}}), }, { { name = 'buffer' } }),
sorting = { sorting = {
priority_weight = 2, priority_weight = 2,
comparators = { comparators = {
@ -203,13 +203,13 @@ cmp.setup({
cmp.setup.cmdline('/', { cmp.setup.cmdline('/', {
mapping = cmp.mapping.preset.cmdline(), mapping = cmp.mapping.preset.cmdline(),
sources = {{name = 'buffer'}} sources = { { name = 'buffer' } }
}) })
cmp.setup.cmdline(':', { cmp.setup.cmdline(':', {
mapping = cmp.mapping.preset.cmdline(), mapping = cmp.mapping.preset.cmdline(),
sources = cmp.config.sources({{name = 'path'}}, { sources = cmp.config.sources({ { name = 'path' } }, {
{name = 'cmdline', option = {ignore_cmds = {'Man', '!'}}} { name = 'cmdline', option = { ignore_cmds = { 'Man', '!' } } }
}) })
}) })
@ -250,7 +250,7 @@ for _, lsp in ipairs(servers) do
} }
} }
else else
lspconfig[lsp].setup {capabilities = capabilities} lspconfig[lsp].setup { capabilities = capabilities }
end end
end end