undo cmp keybind stuff

This commit is contained in:
Daniel Fichtinger 2024-11-07 01:21:32 -05:00
parent 1740badbc6
commit 47fb0cb5dc

View file

@ -1,45 +1,45 @@
return { return {
"hrsh7th/nvim-cmp", "hrsh7th/nvim-cmp",
---@param opts cmp.ConfigSchema -- ---@param opts cmp.ConfigSchema
opts = function(_, opts) -- opts = function(_, opts)
local has_words_before = function() -- local has_words_before = function()
unpack = unpack or table.unpack -- unpack = unpack or table.unpack
local line, col = unpack(vim.api.nvim_win_get_cursor(0)) -- local line, col = unpack(vim.api.nvim_win_get_cursor(0))
return col ~= 0 and vim.api.nvim_buf_get_lines(0, line - 1, line, true)[1]:sub(col, col):match("%s") == nil -- return col ~= 0 and vim.api.nvim_buf_get_lines(0, line - 1, line, true)[1]:sub(col, col):match("%s") == nil
end -- end
local cmp = require("cmp") -- local cmp = require("cmp")
opts.mapping = vim.tbl_extend("force", opts.mapping, { -- opts.mapping = vim.tbl_extend("force", opts.mapping, {
["<Tab>"] = cmp.mapping(function(fallback) -- ["<Tab>"] = cmp.mapping(function(fallback)
if cmp.visible() then -- if cmp.visible() then
-- You could replace select_next_item() with confirm({ select = true }) to get VS Code autocompletion behavior -- -- You could replace select_next_item() with confirm({ select = true }) to get VS Code autocompletion behavior
-- cmp.select_next_item() -- -- cmp.select_next_item()
cmp.confirm({ select = true }) -- cmp.confirm({ select = true })
elseif vim.snippet.active({ direction = 1 }) then -- elseif vim.snippet.active({ direction = 1 }) then
vim.schedule(function() -- vim.schedule(function()
vim.snippet.jump(1) -- vim.snippet.jump(1)
end) -- end)
elseif has_words_before() then -- elseif has_words_before() then
cmp.complete() -- cmp.complete()
else -- else
fallback() -- fallback()
end -- end
end, { "i", "s" }), -- end, { "i", "s" }),
["<S-Tab>"] = cmp.mapping(function(fallback) -- ["<S-Tab>"] = cmp.mapping(function(fallback)
if cmp.visible() then -- if cmp.visible() then
cmp.select_prev_item() -- cmp.select_prev_item()
elseif vim.snippet.active({ direction = -1 }) then -- elseif vim.snippet.active({ direction = -1 }) then
vim.schedule(function() -- vim.schedule(function()
vim.snippet.jump(-1) -- vim.snippet.jump(-1)
end) -- end)
else -- else
fallback() -- fallback()
end -- end
end, { "i", "s" }), -- end, { "i", "s" }),
["<CR>"] = cmp.mapping(function(fallback) -- ["<CR>"] = cmp.mapping(function(fallback)
fallback() -- fallback()
end, { "i", "s" }), -- end, { "i", "s" }),
}) -- })
end, -- end,
} }