Compare commits
	
		
			6 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 624f61e383 | ||
|   | 25eacd32ac | ||
|   | f40a2a1faa | ||
|   | 3f404079dc | ||
|   | 0270a39a7b | ||
|   | b2e012cb83 | 
| @@ -180,3 +180,13 @@ map("n", "<leader><tab><tab>", "<cmd>tabnew<cr>", { desc = "New Tab" }) | ||||
| map("n", "<leader><tab>]", "<cmd>tabnext<cr>", { desc = "Next Tab" }) | ||||
| map("n", "<leader><tab>d", "<cmd>tabclose<cr>", { desc = "Close Tab" }) | ||||
| map("n", "<leader><tab>[", "<cmd>tabprevious<cr>", { desc = "Previous Tab" }) | ||||
|  | ||||
| -- native snippets. only needed on < 0.11, as 0.11 creates these by default | ||||
| if vim.fn.has("nvim-0.11") == 0 then | ||||
|   map("s", "<Tab>", function() | ||||
|     return vim.snippet.active({ direction = 1 }) and "<cmd>lua vim.snippet.jump(1)<cr>" or "<Tab>" | ||||
|   end, { expr = true, desc = "Jump Next" }) | ||||
|   map({ "i", "s" }, "<S-Tab>", function() | ||||
|     return vim.snippet.active({ direction = -1 }) and "<cmd>lua vim.snippet.jump(-1)<cr>" or "<S-Tab>" | ||||
|   end, { expr = true, desc = "Jump Previous" }) | ||||
| end | ||||
|   | ||||
| @@ -11,6 +11,10 @@ vim.g.autoformat = true | ||||
| -- enabled with `:LazyExtras` | ||||
| vim.g.lazyvim_picker = "auto" | ||||
|  | ||||
| -- if the completion engine supports the AI source, | ||||
| -- use that instead of inline suggestions | ||||
| vim.g.ai_cmp = true | ||||
|  | ||||
| -- LazyVim root dir detection | ||||
| -- Each entry can be: | ||||
| -- * the name of a detector function like `lsp` or `cwd` | ||||
|   | ||||
| @@ -43,6 +43,9 @@ return { | ||||
|             cmp.abort() | ||||
|             fallback() | ||||
|           end, | ||||
|           ["<tab>"] = function(fallback) | ||||
|             return LazyVim.cmp.map({ "snippet_forward", "ai_accept" }, fallback)() | ||||
|           end, | ||||
|         }), | ||||
|         sources = cmp.config.sources({ | ||||
|           { name = "nvim_lsp" }, | ||||
| @@ -72,9 +75,10 @@ return { | ||||
|           end, | ||||
|         }, | ||||
|         experimental = { | ||||
|           ghost_text = { | ||||
|           -- only show ghost text when we show ai completions | ||||
|           ghost_text = vim.g.ai_cmp and { | ||||
|             hl_group = "CmpGhostText", | ||||
|           }, | ||||
|           } or false, | ||||
|         }, | ||||
|         sorting = defaults.sorting, | ||||
|       } | ||||
| @@ -105,17 +109,6 @@ return { | ||||
|         table.insert(opts.sources, { name = "snippets" }) | ||||
|       end | ||||
|     end, | ||||
|     init = function() | ||||
|       -- Neovim enabled snippet navigation mappings by default in v0.11 | ||||
|       if vim.fn.has("nvim-0.11") == 0 then | ||||
|         vim.keymap.set({ "i", "s" }, "<Tab>", function() | ||||
|           return vim.snippet.active({ direction = 1 }) and "<cmd>lua vim.snippet.jump(1)<cr>" or "<Tab>" | ||||
|         end, { expr = true, silent = true }) | ||||
|         vim.keymap.set({ "i", "s" }, "<S-Tab>", function() | ||||
|           return vim.snippet.active({ direction = -1 }) and "<cmd>lua vim.snippet.jump(-1)<cr>" or "<S-Tab>" | ||||
|         end, { expr = true, silent = true }) | ||||
|       end | ||||
|     end, | ||||
|   }, | ||||
|  | ||||
|   -- auto pairs | ||||
|   | ||||
| @@ -1,18 +1,42 @@ | ||||
| return { | ||||
|  | ||||
|   -- codeium | ||||
|   { | ||||
|     "Exafunction/codeium.nvim", | ||||
|     cmd = "Codeium", | ||||
|     build = ":Codeium Auth", | ||||
|     opts = { | ||||
|       enable_cmp_source = vim.g.ai_cmp, | ||||
|       virtual_text = { | ||||
|         enabled = not vim.g.ai_cmp, | ||||
|         key_bindings = { | ||||
|           accept = false, -- handled by nvim-cmp / blink.cmp | ||||
|           next = "<M-]>", | ||||
|           prev = "<M-[>", | ||||
|         }, | ||||
|       }, | ||||
|     }, | ||||
|   }, | ||||
|  | ||||
|   -- add ai_accept action | ||||
|   { | ||||
|     "Exafunction/codeium.nvim", | ||||
|     opts = function() | ||||
|       LazyVim.cmp.actions.ai_accept = function() | ||||
|         if require("codeium.virtual_text").get_current_completion_item() then | ||||
|           LazyVim.create_undo() | ||||
|           vim.api.nvim_input(require("codeium.virtual_text").accept()) | ||||
|           return true | ||||
|         end | ||||
|       end | ||||
|     end, | ||||
|   }, | ||||
|  | ||||
|   -- codeium cmp source | ||||
|   { | ||||
|     "nvim-cmp", | ||||
|     dependencies = { | ||||
|       -- codeium | ||||
|       { | ||||
|         "Exafunction/codeium.nvim", | ||||
|         cmd = "Codeium", | ||||
|         build = ":Codeium Auth", | ||||
|         opts = {}, | ||||
|       }, | ||||
|     }, | ||||
|     ---@param opts cmp.ConfigSchema | ||||
|     optional = true, | ||||
|     dependencies = { "codeium.nvim" }, | ||||
|     opts = function(_, opts) | ||||
|       table.insert(opts.sources, 1, { | ||||
|         name = "codeium", | ||||
| @@ -30,4 +54,18 @@ return { | ||||
|       table.insert(opts.sections.lualine_x, 2, LazyVim.lualine.cmp_source("codeium")) | ||||
|     end, | ||||
|   }, | ||||
|  | ||||
|   { | ||||
|     "saghen/blink.cmp", | ||||
|     optional = true, | ||||
|     opts = { | ||||
|       sources = { | ||||
|         compat = vim.g.ai_cmp and { "codeium" } or nil, | ||||
|       }, | ||||
|     }, | ||||
|     dependencies = { | ||||
|       "codeium.nvim", | ||||
|       vim.g.ai_cmp and "saghen/blink.compat" or nil, | ||||
|     }, | ||||
|   }, | ||||
| } | ||||
|   | ||||
| @@ -5,8 +5,17 @@ return { | ||||
|     "zbirenbaum/copilot.lua", | ||||
|     cmd = "Copilot", | ||||
|     build = ":Copilot auth", | ||||
|     event = "InsertEnter", | ||||
|     opts = { | ||||
|       suggestion = { enabled = false }, | ||||
|       suggestion = { | ||||
|         enabled = not vim.g.ai_cmp, | ||||
|         auto_trigger = true, | ||||
|         keymap = { | ||||
|           accept = false, -- handled by nvim-cmp / blink.cmp | ||||
|           next = "<M-]>", | ||||
|           prev = "<M-[>", | ||||
|         }, | ||||
|       }, | ||||
|       panel = { enabled = false }, | ||||
|       filetypes = { | ||||
|         markdown = true, | ||||
| @@ -14,6 +23,22 @@ return { | ||||
|       }, | ||||
|     }, | ||||
|   }, | ||||
|  | ||||
|   -- add ai_accept action | ||||
|   { | ||||
|     "zbirenbaum/copilot.lua", | ||||
|     opts = function() | ||||
|       LazyVim.cmp.actions.ai_accept = function() | ||||
|         if require("copilot.suggestion").is_visible() then | ||||
|           LazyVim.create_undo() | ||||
|           require("copilot.suggestion").accept() | ||||
|           return true | ||||
|         end | ||||
|       end | ||||
|     end, | ||||
|   }, | ||||
|  | ||||
|   -- lualine | ||||
|   { | ||||
|     "nvim-lualine/lualine.nvim", | ||||
|     optional = true, | ||||
| @@ -55,70 +80,50 @@ return { | ||||
|   -- copilot cmp source | ||||
|   { | ||||
|     "nvim-cmp", | ||||
|     dependencies = { | ||||
|     optional = true, | ||||
|     dependencies = { -- this will only be evaluated if nvim-cmp is enabled | ||||
|       { | ||||
|         "zbirenbaum/copilot-cmp", | ||||
|         dependencies = "copilot.lua", | ||||
|         enabled = vim.g.ai_cmp, -- only enable if wanted | ||||
|         opts = {}, | ||||
|         config = function(_, opts) | ||||
|           local copilot_cmp = require("copilot_cmp") | ||||
|           copilot_cmp.setup(opts) | ||||
|           -- attach cmp source whenever copilot attaches | ||||
|           -- fixes lazy-loading issues with the copilot cmp source | ||||
|           LazyVim.lsp.on_attach(function(client) | ||||
|           LazyVim.lsp.on_attach(function() | ||||
|             copilot_cmp._on_insert_enter({}) | ||||
|           end, "copilot") | ||||
|         end, | ||||
|       }, | ||||
|     }, | ||||
|     ---@param opts cmp.ConfigSchema | ||||
|     opts = function(_, opts) | ||||
|       table.insert(opts.sources, 1, { | ||||
|         name = "copilot", | ||||
|         group_index = 1, | ||||
|         priority = 100, | ||||
|       }) | ||||
|     end, | ||||
|   }, | ||||
|  | ||||
|   { | ||||
|     "saghen/blink.cmp", | ||||
|     optional = true, | ||||
|     specs = { | ||||
|       { | ||||
|         "zbirenbaum/copilot.lua", | ||||
|         event = "InsertEnter", | ||||
|         opts = { | ||||
|           suggestion = { | ||||
|             enabled = true, | ||||
|             auto_trigger = true, | ||||
|             keymap = { accept = false }, | ||||
|         specs = { | ||||
|           { | ||||
|             "nvim-cmp", | ||||
|             ---@param opts cmp.ConfigSchema | ||||
|             opts = function(_, opts) | ||||
|               table.insert(opts.sources, 1, { | ||||
|                 name = "copilot", | ||||
|                 group_index = 1, | ||||
|                 priority = 100, | ||||
|               }) | ||||
|             end, | ||||
|           }, | ||||
|         }, | ||||
|       }, | ||||
|     }, | ||||
|   }, | ||||
|  | ||||
|   -- blink.cmp | ||||
|   { | ||||
|     "saghen/blink.cmp", | ||||
|     optional = true, | ||||
|     opts = { | ||||
|       windows = { | ||||
|         ghost_text = { | ||||
|           enabled = false, | ||||
|         }, | ||||
|       }, | ||||
|       keymap = { | ||||
|         ["<Tab>"] = { | ||||
|           function(cmp) | ||||
|             if cmp.is_in_snippet() then | ||||
|               return cmp.accept() | ||||
|             elseif require("copilot.suggestion").is_visible() then | ||||
|               LazyVim.create_undo() | ||||
|               require("copilot.suggestion").accept() | ||||
|               return true | ||||
|             else | ||||
|               return cmp.select_and_accept() | ||||
|             end | ||||
|           end, | ||||
|           "snippet_forward", | ||||
|           "fallback", | ||||
|         }, | ||||
|       windows = { ghost_text = { enabled = false } }, | ||||
|     }, | ||||
|     specs = { | ||||
|       -- blink has no copilot source, so force enable suggestions | ||||
|       { | ||||
|         "zbirenbaum/copilot.lua", | ||||
|         opts = { suggestion = { enabled = true } }, | ||||
|       }, | ||||
|     }, | ||||
|   }, | ||||
|   | ||||
| @@ -1,3 +1,10 @@ | ||||
| if lazyvim_docs then | ||||
|   -- set to `true` to follow the main branch | ||||
|   -- you need to have a working rust toolchain to build the plugin | ||||
|   -- in this case. | ||||
|   vim.g.lazyvim_blink_main = false | ||||
| end | ||||
|  | ||||
| return { | ||||
|   { | ||||
|     "hrsh7th/nvim-cmp", | ||||
| @@ -5,8 +12,12 @@ return { | ||||
|   }, | ||||
|   { | ||||
|     "saghen/blink.cmp", | ||||
|     version = "*", | ||||
|     opts_extend = { "sources.completion.enabled_providers" }, | ||||
|     version = not vim.g.lazyvim_blink_main and "*", | ||||
|     build = vim.g.lazyvim_blink_main and "cargo build --release", | ||||
|     opts_extend = { | ||||
|       "sources.completion.enabled_providers", | ||||
|       "sources.compat", | ||||
|     }, | ||||
|     dependencies = { | ||||
|       "rafamadriz/friendly-snippets", | ||||
|       -- add blink.compat to dependencies | ||||
| @@ -35,7 +46,7 @@ return { | ||||
|           auto_show = true, | ||||
|         }, | ||||
|         ghost_text = { | ||||
|           enabled = true, | ||||
|           enabled = vim.g.ai_cmp, | ||||
|         }, | ||||
|       }, | ||||
|  | ||||
| @@ -45,6 +56,9 @@ return { | ||||
|       -- experimental signature help support | ||||
|       -- trigger = { signature_help = { enabled = true } } | ||||
|       sources = { | ||||
|         -- adding any nvim-cmp sources here will enable them | ||||
|         -- with blink.compat | ||||
|         compat = {}, | ||||
|         completion = { | ||||
|           -- remember to enable your providers here | ||||
|           enabled_providers = { "lsp", "path", "snippets", "buffer" }, | ||||
| @@ -53,8 +67,28 @@ return { | ||||
|  | ||||
|       keymap = { | ||||
|         preset = "enter", | ||||
|         ["<Tab>"] = { | ||||
|           LazyVim.cmp.map({ "snippet_forward", "ai_accept" }), | ||||
|           "fallback", | ||||
|         }, | ||||
|       }, | ||||
|     }, | ||||
|     ---@param opts blink.cmp.Config | { sources: { compat: string[] } } | ||||
|     config = function(_, opts) | ||||
|       -- setup compat sources | ||||
|       local enabled = opts.sources.completion.enabled_providers | ||||
|       for _, source in ipairs(opts.sources.compat or {}) do | ||||
|         opts.sources.providers[source] = vim.tbl_deep_extend( | ||||
|           "force", | ||||
|           { name = source, module = "blink.compat.source" }, | ||||
|           opts.sources.providers[source] or {} | ||||
|         ) | ||||
|         if type(enabled) == "table" and not vim.tbl_contains(enabled, source) then | ||||
|           table.insert(enabled, source) | ||||
|         end | ||||
|       end | ||||
|       require("blink.cmp").setup(opts) | ||||
|     end, | ||||
|   }, | ||||
|  | ||||
|   -- add icons | ||||
|   | ||||
| @@ -1,4 +1,8 @@ | ||||
| return { | ||||
|   -- disable builtin snippet support | ||||
|   { "garymjr/nvim-snippets", enabled = false }, | ||||
|  | ||||
|   -- add luasnip | ||||
|   { | ||||
|     "L3MON4D3/LuaSnip", | ||||
|     lazy = true, | ||||
| @@ -12,43 +16,56 @@ return { | ||||
|           require("luasnip.loaders.from_vscode").lazy_load() | ||||
|         end, | ||||
|       }, | ||||
|       { | ||||
|         "nvim-cmp", | ||||
|         dependencies = { | ||||
|           "saadparwaiz1/cmp_luasnip", | ||||
|         }, | ||||
|         opts = function(_, opts) | ||||
|           opts.snippet = { | ||||
|             expand = function(args) | ||||
|               require("luasnip").lsp_expand(args.body) | ||||
|             end, | ||||
|           } | ||||
|           table.insert(opts.sources, { name = "luasnip" }) | ||||
|         end, | ||||
|       }, | ||||
|     }, | ||||
|     opts = { | ||||
|       history = true, | ||||
|       delete_check_events = "TextChanged", | ||||
|     }, | ||||
|   }, | ||||
|  | ||||
|   -- add snippet_forward action | ||||
|   { | ||||
|     "L3MON4D3/LuaSnip", | ||||
|     opts = function() | ||||
|       LazyVim.cmp.actions.snippet_forward = function() | ||||
|         if require("luasnip").jumpable(1) then | ||||
|           require("luasnip").jump(1) | ||||
|           return true | ||||
|         end | ||||
|       end | ||||
|     end, | ||||
|   }, | ||||
|  | ||||
|   -- nvim-cmp integration | ||||
|   { | ||||
|     "nvim-cmp", | ||||
|     optional = true, | ||||
|     dependencies = { "saadparwaiz1/cmp_luasnip" }, | ||||
|     opts = function(_, opts) | ||||
|       opts.snippet = { | ||||
|         expand = function(args) | ||||
|           require("luasnip").lsp_expand(args.body) | ||||
|         end, | ||||
|       } | ||||
|       table.insert(opts.sources, { name = "luasnip" }) | ||||
|     end, | ||||
|     -- stylua: ignore | ||||
|     keys = { | ||||
|       { | ||||
|         "<tab>", | ||||
|         function() | ||||
|           return require("luasnip").jumpable(1) and "<Plug>luasnip-jump-next" or "<tab>" | ||||
|         end, | ||||
|         expr = true, silent = true, mode = "i", | ||||
|       }, | ||||
|       { "<tab>", function() require("luasnip").jump(1) end, mode = "s" }, | ||||
|       { "<s-tab>", function() require("luasnip").jump(-1) end, mode = { "i", "s" } }, | ||||
|     }, | ||||
|   }, | ||||
|  | ||||
|   -- blink.cmp integration | ||||
|   { | ||||
|     "garymjr/nvim-snippets", | ||||
|     enabled = false, | ||||
|     "saghen/blink.cmp", | ||||
|     optional = true, | ||||
|     opts = { | ||||
|       accept = { | ||||
|         expand_snippet = function(...) | ||||
|           return require("luasnip").lsp_expand(...) | ||||
|         end, | ||||
|       }, | ||||
|     }, | ||||
|   }, | ||||
| } | ||||
|   | ||||
| @@ -1,6 +1,36 @@ | ||||
| ---@class lazyvim.util.cmp | ||||
| local M = {} | ||||
|  | ||||
| ---@alias lazyvim.util.cmp.Action fun():boolean? | ||||
| ---@type table<string, lazyvim.util.cmp.Action> | ||||
| M.actions = { | ||||
|   -- Native Snippets | ||||
|   snippet_forward = function() | ||||
|     if vim.snippet.active({ direction = 1 }) then | ||||
|       vim.schedule(function() | ||||
|         vim.snippet.jump(1) | ||||
|       end) | ||||
|       return true | ||||
|     end | ||||
|   end, | ||||
| } | ||||
|  | ||||
| ---@param actions string[] | ||||
| ---@param fallback? string|fun() | ||||
| function M.map(actions, fallback) | ||||
|   return function() | ||||
|     for _, name in ipairs(actions) do | ||||
|       if M.actions[name] then | ||||
|         local ret = M.actions[name]() | ||||
|         if ret then | ||||
|           return true | ||||
|         end | ||||
|       end | ||||
|     end | ||||
|     return type(fallback) == "function" and fallback() or fallback | ||||
|   end | ||||
| end | ||||
|  | ||||
| ---@alias Placeholder {n:number, text:string} | ||||
|  | ||||
| ---@param snippet string | ||||
|   | ||||
| @@ -7,7 +7,7 @@ function M.cmp_source(name, icon) | ||||
|     if not package.loaded["cmp"] then | ||||
|       return | ||||
|     end | ||||
|     for _, s in ipairs(require("cmp").core.sources) do | ||||
|     for _, s in ipairs(require("cmp").core.sources or {}) do | ||||
|       if s.name == name then | ||||
|         if s.source:is_available() then | ||||
|           started = true | ||||
|   | ||||
		Reference in New Issue
	
	Block a user