return { { 'mason-org/mason.nvim', event = 'VeryLazy', opts = {}, }, { 'neovim/nvim-lspconfig', event = 'VeryLazy', }, { "mason-org/mason-lspconfig.nvim", event = 'VeryLazy', opts = {}, dependencies = { { "mason-org/mason.nvim", opts = {} }, "neovim/nvim-lspconfig", }, }, -- { -- "MysticalDevil/inlay-hints.nvim", -- event = "LspAttach", -- dependencies = { "neovim/nvim-lspconfig" }, -- config = function() -- require("inlay-hints").setup() -- end -- }, -- { 'saghen/blink.cmp', -- optional: provides snippets for the snippet source -- dependencies = { 'L3MON4D3/LuaSnip' }, -- use a release tag to download pre-built binaries version = '1.*', -- AND/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 = { -- 'default' (recommended) for mappings similar to built-in completions (C-y to accept) -- 'super-tab' for mappings similar to vscode (tab to accept) -- 'enter' for enter to accept -- 'none' for no mappings -- -- 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) -- -- See :h blink-cmp-config-keymap for defining your own keymap keymap = { preset = 'default' }, -- snippets = { preset = 'mini_snippets' }, appearance = { -- 'mono' (default) for 'Nerd Font Mono' or 'normal' for 'Nerd Font' -- Adjusts spacing to ensure icons are aligned nerd_font_variant = 'mono' }, cmdline = { completion = { menu = { auto_show = true } }, }, -- (Default) Only show the documentation popup when manually triggered completion = { documentation = { auto_show = false }, list = { selection = { preselect = true, auto_insert = false, }, }, ghost_text = { enabled = true, show_with_menu = true, }, menu = { auto_show = true, draw = { components = { -- customize the drawing of kind icons kind_icon = { text = function(ctx) -- default kind icon local icon = ctx.kind_icon -- if LSP source, check for color derived from documentation if ctx.item.source_name == "LSP" then local color_item = require("nvim-highlight-colors").format(ctx.item.documentation, { kind = ctx.kind }) if color_item and color_item.abbr ~= "" then icon = color_item.abbr end end return icon .. ctx.icon_gap end, highlight = function(ctx) -- default highlight group local highlight = "BlinkCmpKind" .. ctx.kind -- if LSP source, check for color derived from documentation if ctx.item.source_name == "LSP" then local color_item = require("nvim-highlight-colors").format(ctx.item.documentation, { kind = ctx.kind }) if color_item and color_item.abbr_hl_group then highlight = color_item.abbr_hl_group end end return highlight end, }, }, }, }, }, -- Default list of enabled providers defined so that you can extend it -- elsewhere in your config, without redefining it, due to `opts_extend` sources = { default = { 'lsp', 'path', 'snippets', 'buffer' }, }, -- (Default) Rust fuzzy matcher for typo resistance and significantly better performance -- You may use a lua implementation instead by using `implementation = "lua"` or fallback to the lua implementation, -- when the Rust fuzzy matcher is not available, by using `implementation = "prefer_rust"` -- -- See the fuzzy documentation for more information fuzzy = { implementation = "prefer_rust_with_warning" } }, opts_extend = { "sources.default" } } }