try blink again
This commit is contained in:
@@ -1,235 +1,86 @@
|
|||||||
return {
|
return {
|
||||||
'saghen/blink.cmp',
|
'saghen/blink.cmp',
|
||||||
lazy = false, -- lazy loading handled internally
|
|
||||||
-- optional: provides snippets for the snippet source
|
-- optional: provides snippets for the snippet source
|
||||||
dependencies = {
|
dependencies = {
|
||||||
'rafamadriz/friendly-snippets',
|
|
||||||
'giuxtaposition/blink-cmp-copilot',
|
|
||||||
{
|
|
||||||
'fang2hou/blink-copilot',
|
|
||||||
opts = {
|
|
||||||
max_completions = 1, -- Global default for max completions
|
|
||||||
max_attempts = 2, -- Global default for max attempts
|
|
||||||
-- `kind` is not set, so the default value is "Copilot"
|
|
||||||
},
|
|
||||||
},
|
|
||||||
'dmitmel/cmp-cmdline-history',
|
|
||||||
'onsails/lspkind.nvim',
|
|
||||||
'folke/lazydev.nvim',
|
|
||||||
'L3MON4D3/LuaSnip',
|
|
||||||
{
|
{
|
||||||
'saghen/blink.compat',
|
'saghen/blink.compat',
|
||||||
-- use the latest release, via version = '*', if you also use the latest release for blink.cmp
|
-- use v2.* for blink.cmp v1.*
|
||||||
version = '*',
|
version = '2.*',
|
||||||
-- lazy.nvim will automatically load the plugin when it's required by blink.cmp
|
|
||||||
lazy = true,
|
lazy = true,
|
||||||
-- make sure to set opts so that lazy.nvim calls blink.compat's setup
|
|
||||||
opts = {},
|
opts = {},
|
||||||
},
|
},
|
||||||
'rcarriga/cmp-dap',
|
'rafamadriz/friendly-snippets',
|
||||||
|
'dmitmel/cmp-cmdline-history',
|
||||||
},
|
},
|
||||||
|
|
||||||
-- use a release tag to download pre-built binaries
|
-- use a release tag to download pre-built binaries
|
||||||
version = '*',
|
version = '1.*',
|
||||||
-- OR build from source, requires nightly: https://rust-lang.github.io/rustup/concepts/channels.html#working-with-nightly-rust
|
|
||||||
-- build = 'cargo build --release',
|
|
||||||
-- If you use nix, you can build from source using latest nightly rust with:
|
|
||||||
-- build = 'nix run .#build-plugin',
|
|
||||||
|
|
||||||
|
---@module 'blink.cmp'
|
||||||
|
---@type blink.cmp.Config
|
||||||
opts = {
|
opts = {
|
||||||
-- 'default' for mappings similar to built-in completion
|
-- 'default' (recommended) for mappings similar to built-in completions (C-y to accept)
|
||||||
-- 'super-tab' for mappings similar to vscode (tab to accept, arrow keys to navigate)
|
-- 'super-tab' for mappings similar to vscode (tab to accept)
|
||||||
-- 'enter' for mappings similar to 'super-tab' but with 'enter' to accept
|
-- 'enter' for enter to accept
|
||||||
-- see the "default configuration" section below for full documentation on how to define
|
-- 'none' for no mappings
|
||||||
-- your own keymap.
|
--
|
||||||
|
-- All presets have the following mappings:
|
||||||
|
-- C-space: Open menu or open docs if already open
|
||||||
|
-- C-n/C-p or Up/Down: Select next/previous item
|
||||||
|
-- C-e: Hide menu
|
||||||
|
-- C-k: Toggle signature help (if signature.enabled = true)
|
||||||
keymap = { preset = 'enter' },
|
keymap = { preset = 'enter' },
|
||||||
|
|
||||||
appearance = {
|
appearance = {
|
||||||
-- Sets the fallback highlight groups to nvim-cmp's highlight groups
|
|
||||||
-- Useful for when your theme doesn't support blink.cmp
|
|
||||||
-- will be removed in a future release
|
|
||||||
use_nvim_cmp_as_default = true,
|
|
||||||
-- Set to 'mono' for 'Nerd Font Mono' or 'normal' for 'Nerd Font'
|
|
||||||
-- Adjusts spacing to ensure icons are aligned
|
|
||||||
nerd_font_variant = 'mono',
|
nerd_font_variant = 'mono',
|
||||||
},
|
},
|
||||||
|
|
||||||
enabled = function() return (vim.bo.buftype ~= 'prompt' and vim.b.completion ~= false) or require('cmp_dap').is_dap_buffer() end,
|
-- (Default) Only show the documentation popup when manually triggered
|
||||||
-- default list of enabled providers defined so that you can extend it
|
completion = {
|
||||||
-- elsewhere in your config, without redefining it, via `opts_extend`
|
documentation = { auto_show = true },
|
||||||
|
list = {
|
||||||
|
selection = {
|
||||||
|
preselect = false,
|
||||||
|
auto_insert = false,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
|
||||||
sources = {
|
sources = {
|
||||||
default = { 'copilot', 'lazydev', 'lsp', 'path', 'snippets', 'buffer', 'codeium' },
|
default = { 'lsp', 'path', 'snippets', 'buffer' },
|
||||||
|
|
||||||
per_filetype = {
|
|
||||||
['dap-repl'] = {
|
|
||||||
'copilot',
|
|
||||||
'dap',
|
|
||||||
'snippets',
|
|
||||||
'path',
|
|
||||||
'buffer',
|
|
||||||
},
|
|
||||||
},
|
|
||||||
|
|
||||||
providers = {
|
providers = {
|
||||||
copilot = {
|
lsp = {
|
||||||
name = 'copilot',
|
fallbacks = {},
|
||||||
module = 'blink-copilot',
|
|
||||||
score_offset = 100,
|
|
||||||
async = true,
|
|
||||||
opts = {
|
|
||||||
-- Local options override global ones
|
|
||||||
-- Final settings: max_completions = 3, max_attempts = 2, kind = "Copilot"
|
|
||||||
max_completions = 3, -- Override global max_completions
|
|
||||||
},
|
|
||||||
},
|
|
||||||
lazydev = {
|
|
||||||
name = 'LazyDev',
|
|
||||||
module = 'lazydev.integrations.blink',
|
|
||||||
-- make lazydev completions top priority (see `:h blink.cmp`)
|
|
||||||
score_offset = 100,
|
|
||||||
},
|
|
||||||
codeium = { -- TODO: Replace with https://github.com/Exafunction/codeium.nvim/pull/264
|
|
||||||
name = 'codeium', -- IMPORTANT: use the same name as you would for nvim-cmp
|
|
||||||
module = 'blink.compat.source',
|
|
||||||
async = true,
|
|
||||||
},
|
},
|
||||||
cmdline_history = {
|
cmdline_history = {
|
||||||
name = 'cmdline_history',
|
name = 'cmdline_history',
|
||||||
module = 'blink.compat.source',
|
module = 'blink.compat.source',
|
||||||
score_offset = -50,
|
score_offset = -3,
|
||||||
},
|
|
||||||
dap = {
|
|
||||||
name = 'dap',
|
|
||||||
module = 'blink.compat.source',
|
|
||||||
async = false,
|
|
||||||
enabled = function() return require('cmp_dap').is_dap_buffer() end,
|
|
||||||
},
|
|
||||||
buffer = {
|
|
||||||
name = 'Buffer',
|
|
||||||
module = 'blink.cmp.sources.buffer',
|
|
||||||
opts = {
|
|
||||||
-- default to all visible buffers
|
|
||||||
get_bufnrs = function()
|
|
||||||
return vim
|
|
||||||
.iter(vim.api.nvim_list_wins())
|
|
||||||
:map(function(win) return vim.api.nvim_win_get_buf(win) end)
|
|
||||||
:filter(function(buf) return vim.bo[buf].buftype ~= 'nofile' end)
|
|
||||||
:totable()
|
|
||||||
end,
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
||||||
cmdline = {
|
|
||||||
sources = function()
|
|
||||||
local type = vim.fn.getcmdtype()
|
|
||||||
-- Search forward and backward
|
|
||||||
if type == '/' or type == '?' then
|
|
||||||
return { 'buffer' }
|
|
||||||
end
|
|
||||||
-- Commands
|
|
||||||
if type == ':' or type == '@' then
|
|
||||||
return { 'cmdline', 'buffer', 'cmdline_history' }
|
|
||||||
end
|
|
||||||
return {}
|
|
||||||
end,
|
|
||||||
completion = {
|
|
||||||
trigger = {
|
|
||||||
show_on_blocked_trigger_characters = {},
|
|
||||||
show_on_x_blocked_trigger_characters = nil, -- Inherits from top level `completion.trigger.show_on_blocked_trigger_characters` config when not set
|
|
||||||
},
|
|
||||||
list = {
|
|
||||||
selection = {
|
|
||||||
auto_insert = false,
|
|
||||||
preselect = false,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
menu = {
|
|
||||||
auto_show = true, -- Inherits from top level `completion.menu.auto_show` config when not set
|
|
||||||
},
|
|
||||||
},
|
|
||||||
keymap = {
|
|
||||||
['<down>'] = { 'select_next', 'fallback' },
|
|
||||||
['<up>'] = { 'select_prev', 'fallback' },
|
|
||||||
['<CR>'] = { 'accept', 'fallback' },
|
|
||||||
['<C-e>'] = { 'cancel' },
|
|
||||||
},
|
|
||||||
},
|
|
||||||
|
|
||||||
completion = {
|
|
||||||
list = {
|
|
||||||
selection = {
|
|
||||||
auto_insert = false,
|
|
||||||
preselect = false,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
accept = {
|
|
||||||
dot_repeat = false,
|
|
||||||
},
|
|
||||||
menu = {
|
|
||||||
max_height = 25,
|
|
||||||
draw = {
|
|
||||||
padding = 1,
|
|
||||||
gap = 1,
|
|
||||||
-- treesitter = { 'lsp' },
|
|
||||||
components = {
|
|
||||||
kind_icon = {
|
|
||||||
ellipsis = false,
|
|
||||||
text = function(ctx)
|
|
||||||
local lspkind = require('lspkind')
|
|
||||||
local icon = ctx.kind_icon
|
|
||||||
if ctx.source_name == 'cmdline_history' then
|
|
||||||
icon = require('nvim-web-devicons').get_icon('log')
|
|
||||||
elseif vim.tbl_contains({ 'Path' }, ctx.source_name) then
|
|
||||||
local dev_icon, _ = require('nvim-web-devicons').get_icon(ctx.label)
|
|
||||||
if dev_icon then
|
|
||||||
icon = dev_icon
|
|
||||||
end
|
|
||||||
else
|
|
||||||
icon = lspkind.symbolic(ctx.kind, {
|
|
||||||
mode = 'symbol',
|
|
||||||
})
|
|
||||||
end
|
|
||||||
|
|
||||||
return icon .. ctx.icon_gap
|
|
||||||
end,
|
|
||||||
|
|
||||||
-- Optionally, use the highlight groups from nvim-web-devicons
|
|
||||||
-- You can also add the same function for `kind.highlight` if you want to
|
|
||||||
-- keep the highlight groups in sync with the icons.
|
|
||||||
highlight = function(ctx)
|
|
||||||
local hl = ctx.kind_hl
|
|
||||||
if ctx.source_name == 'cmdline_history' then
|
|
||||||
_, hl = require('nvim-web-devicons').get_icon('log')
|
|
||||||
elseif ctx.source_name == 'cmdline' then
|
|
||||||
_, hl = require('nvim-web-devicons').get_icon('cc')
|
|
||||||
elseif vim.tbl_contains({ 'Path' }, ctx.source_name) then
|
|
||||||
local dev_icon, dev_hl = require('nvim-web-devicons').get_icon(ctx.label)
|
|
||||||
if dev_icon then
|
|
||||||
hl = dev_hl
|
|
||||||
end
|
|
||||||
end
|
|
||||||
return hl
|
|
||||||
end,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
documentation = {
|
|
||||||
auto_show = true,
|
|
||||||
auto_show_delay_ms = 500,
|
|
||||||
treesitter_highlighting = true,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
|
|
||||||
-- experimental signature help support
|
|
||||||
signature = { enabled = true },
|
|
||||||
snippets = {
|
snippets = {
|
||||||
preset = 'luasnip',
|
preset = 'luasnip',
|
||||||
},
|
},
|
||||||
|
signature = {
|
||||||
|
enabled = true,
|
||||||
},
|
},
|
||||||
-- allows extending the providers array elsewhere in your config
|
cmdline = {
|
||||||
-- without having to redefine it
|
keymap = { preset = 'inherit' },
|
||||||
enabled = false,
|
completion = {
|
||||||
|
menu = { auto_show = true },
|
||||||
|
list = {
|
||||||
|
selection = {
|
||||||
|
preselect = false,
|
||||||
|
auto_insert = false,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
sources = { 'buffer', 'cmdline', 'cmdline_history' },
|
||||||
|
},
|
||||||
|
|
||||||
|
fuzzy = { implementation = 'prefer_rust_with_warning' },
|
||||||
|
},
|
||||||
|
opts_extend = { 'sources.default' },
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -147,5 +147,5 @@ return {
|
|||||||
matching = { disallow_symbol_nonprefix_matching = false },
|
matching = { disallow_symbol_nonprefix_matching = false },
|
||||||
})
|
})
|
||||||
end,
|
end,
|
||||||
enabled = true,
|
enabled = false,
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -52,8 +52,8 @@ return {
|
|||||||
}
|
}
|
||||||
|
|
||||||
local capabilities = vim.lsp.protocol.make_client_capabilities()
|
local capabilities = vim.lsp.protocol.make_client_capabilities()
|
||||||
capabilities = require('cmp_nvim_lsp').default_capabilities(capabilities)
|
-- capabilities = require('cmp_nvim_lsp').default_capabilities(capabilities)
|
||||||
-- capabilities = require('blink.cmp').get_lsp_capabilities(capabilities)
|
capabilities = require('blink.cmp').get_lsp_capabilities(capabilities)
|
||||||
vim.lsp.config('*', {
|
vim.lsp.config('*', {
|
||||||
capabilities = capabilities,
|
capabilities = capabilities,
|
||||||
})
|
})
|
||||||
|
|||||||
Reference in New Issue
Block a user