Merge branch 'master' of https://github.com/mightypanders/dotfiles
This commit is contained in:
commit
63c655642e
@ -2,64 +2,83 @@ local cmp = require("cmp")
|
|||||||
local luasnip = require("luasnip")
|
local luasnip = require("luasnip")
|
||||||
|
|
||||||
local has_words_before = function()
|
local has_words_before = function()
|
||||||
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
|
||||||
cmp.setup({
|
cmp.setup({
|
||||||
snippet = {
|
snippet = {
|
||||||
expand = function(args)
|
expand = function(args)
|
||||||
require('luasnip').lsp_expand(args.body) -- For `luasnip` users.
|
require('luasnip').lsp_expand(args.body) -- For `luasnip` users.
|
||||||
end,
|
end,
|
||||||
},
|
},
|
||||||
mapping = {
|
mapping = {
|
||||||
['<C-k>'] = cmp.mapping.select_prev_item(),
|
['<C-k>'] = cmp.mapping.select_prev_item(),
|
||||||
['<C-j>'] = cmp.mapping.select_next_item(),
|
['<C-p>'] = cmp.mapping.select_prev_item(),
|
||||||
['<C-d>'] = cmp.mapping(cmp.mapping.scroll_docs(-4), { 'i', 'c' }),
|
['<C-j>'] = cmp.mapping.select_next_item(),
|
||||||
['<C-f>'] = cmp.mapping(cmp.mapping.scroll_docs(4), { 'i', 'c' }),
|
['<C-n>'] = cmp.mapping.select_next_item(),
|
||||||
['<C-Space>'] = cmp.mapping(cmp.mapping.complete(), { 'i', 'c' }),
|
['<C-d>'] = cmp.mapping(cmp.mapping.scroll_docs(-4), { 'i', 'c' }),
|
||||||
['<C-y>'] = cmp.config.disable, -- Specify `cmp.config.disable` if you want to remove the default `<C-y>` mapping.
|
['<C-f>'] = cmp.mapping(cmp.mapping.scroll_docs(4), { 'i', 'c' }),
|
||||||
['<C-e>'] = cmp.mapping({
|
['<C-Space>'] = cmp.mapping(cmp.mapping.complete(), { 'i', 'c' }),
|
||||||
i = cmp.mapping.abort(),
|
['<C-y>'] = cmp.config.disable, -- Specify `cmp.config.disable` if you want to remove the default `<C-y>` mapping.
|
||||||
c = cmp.mapping.close(),
|
['<C-e>'] = cmp.mapping({
|
||||||
}),
|
i = cmp.mapping.abort(),
|
||||||
['<CR>'] = cmp.mapping.confirm({ select = true }),
|
c = cmp.mapping.close(),
|
||||||
['<Tab>'] = cmp.mapping(function(fallback)
|
}),
|
||||||
if cmp.visible() then
|
['<CR>'] = cmp.mapping.confirm({ select = true }),
|
||||||
cmp.select_next_item()
|
['<Tab>'] = cmp.mapping(function(fallback)
|
||||||
elseif luasnip.expand_or_jumpable() then
|
if cmp.visible() then
|
||||||
luasnip.expand_or_jump()
|
cmp.select_next_item()
|
||||||
elseif has_words_before() then
|
elseif luasnip.expand_or_jumpable() then
|
||||||
cmp.complete()
|
luasnip.expand_or_jump()
|
||||||
else
|
elseif has_words_before() then
|
||||||
fallback()
|
cmp.complete()
|
||||||
end
|
else
|
||||||
end,{"i","s"}),
|
fallback()
|
||||||
['<S-Tab>'] = cmp.mapping(function(fallback)
|
end
|
||||||
if cmp.visible() then
|
end, { "i", "s" }),
|
||||||
cmp.select_prev_item()
|
['<S-Tab>'] = cmp.mapping(function(fallback)
|
||||||
elseif luasnip.jumpable(-1) then
|
if cmp.visible() then
|
||||||
luasnip.jump(-1)
|
cmp.select_prev_item()
|
||||||
else
|
elseif luasnip.jumpable(-1) then
|
||||||
fallback()
|
luasnip.jump(-1)
|
||||||
end
|
else
|
||||||
end,{"i","s"})
|
fallback()
|
||||||
},
|
end
|
||||||
sources = cmp.config.sources({
|
end, { "i", "s" })
|
||||||
{ name = 'nvim_lsp' },
|
},
|
||||||
{ name = 'luasnip' }, -- For luasnip users.
|
sources = cmp.config.sources({
|
||||||
}, {
|
{ name = 'path' },
|
||||||
{ name = 'buffer' },
|
{ name = 'nvim_lsp' },
|
||||||
})
|
{ name = 'nvim_lsp_signature_help' },
|
||||||
})
|
{ name = 'nvim_lua' },
|
||||||
|
{ name = 'buffer' },
|
||||||
cmp.setup.cmdline('/',{
|
{ name = 'luasnip' }, -- For luasnip users.
|
||||||
sources = {
|
}),
|
||||||
{ name = 'buffer' }
|
window = {
|
||||||
}
|
completion = cmp.config.window.bordered(),
|
||||||
|
documentation = cmp.config.window.bordered(),
|
||||||
|
},
|
||||||
|
formatting = {
|
||||||
|
fields = { 'menu', 'abbr', 'kind' },
|
||||||
|
format = function(entry, item)
|
||||||
|
local menu_icon = {
|
||||||
|
nvim_lsp = 'λ',
|
||||||
|
buffer = 'Ω'
|
||||||
|
}
|
||||||
|
item.menu = menu_icon[entry.source.name]
|
||||||
|
return item
|
||||||
|
end
|
||||||
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
cmp.setup.cmdline(':',{
|
cmp.setup.cmdline('/', {
|
||||||
sources = cmp.config.sources({
|
sources = {
|
||||||
{name = 'path'}
|
{ name = 'buffer' }
|
||||||
},{{name='cmdline'}})
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
cmp.setup.cmdline(':', {
|
||||||
|
sources = cmp.config.sources({
|
||||||
|
{ name = 'path' }
|
||||||
|
}, { { name = 'cmdline' } })
|
||||||
})
|
})
|
||||||
|
@ -22,6 +22,12 @@ nmap("<SPACE>","<Nop>")
|
|||||||
nmap("<Esc><Esc>", ":noh<cr>")
|
nmap("<Esc><Esc>", ":noh<cr>")
|
||||||
|
|
||||||
|
|
||||||
|
nmap("<C-f>",":ToggleTerm direction=float<cr>")
|
||||||
|
imap("<C-f>",":ToggleTerm direction=float<cr>")
|
||||||
|
|
||||||
|
nmap("<C-l>",":ToggleTerm direction=horizontal size=10<cr>")
|
||||||
|
imap("<C-l>",":ToggleTerm direction=horizontal size=10<cr>")
|
||||||
|
|
||||||
xmap("p",'\"_dP')
|
xmap("p",'\"_dP')
|
||||||
nmap("<leader>fg", "<cmd>lua require('telescope.builtin').live_grep()<cr>")
|
nmap("<leader>fg", "<cmd>lua require('telescope.builtin').live_grep()<cr>")
|
||||||
nmap("<leader>fb", "<cmd>lua require('telescope.builtin').buffers()<cr>")
|
nmap("<leader>fb", "<cmd>lua require('telescope.builtin').buffers()<cr>")
|
||||||
|
@ -29,24 +29,57 @@ local on_attach = function(client, bufnr)
|
|||||||
vim.keymap.set('n', '<leader>rn', vim.lsp.buf.rename, bufopts)
|
vim.keymap.set('n', '<leader>rn', vim.lsp.buf.rename, bufopts)
|
||||||
vim.keymap.set('n', '<leader>ca', vim.lsp.buf.code_action, bufopts)
|
vim.keymap.set('n', '<leader>ca', vim.lsp.buf.code_action, bufopts)
|
||||||
vim.keymap.set('n', '<leader>gr', vim.lsp.buf.references, bufopts)
|
vim.keymap.set('n', '<leader>gr', vim.lsp.buf.references, bufopts)
|
||||||
vim.keymap.set('n', '<leader>f', vim.lsp.buf.formatting, bufopts)
|
vim.keymap.set('n', '<leader>f', vim.lsp.buf.format, bufopts)
|
||||||
end
|
end
|
||||||
|
|
||||||
local lsp_flags = {
|
local lsp_flags = {
|
||||||
-- This is the default in Nvim 0.7+
|
-- This is the default in Nvim 0.7+
|
||||||
debounce_text_changes = 150,
|
debounce_text_changes = 150,
|
||||||
}
|
}
|
||||||
|
local capabilities = require('cmp_nvim_lsp').default_capabilities(
|
||||||
|
vim.lsp.protocol.make_client_capabilities()
|
||||||
|
)
|
||||||
require('mason-lspconfig').setup_handlers {
|
require('mason-lspconfig').setup_handlers {
|
||||||
function(server_name)
|
function(server_name)
|
||||||
require('lspconfig')[server_name].setup {
|
require('lspconfig')[server_name].setup {
|
||||||
on_attach = on_attach,
|
on_attach = on_attach,
|
||||||
flags = lsp_flags,
|
flags = lsp_flags,
|
||||||
|
capabilities = capabilities
|
||||||
}
|
}
|
||||||
end,
|
end,
|
||||||
['rust_analyzer'] = function()
|
['rust_analyzer'] = function()
|
||||||
require('rust-tools').setup {
|
local rustToolsOpts = {
|
||||||
|
tools = {
|
||||||
|
inlay_hints = {
|
||||||
|
auto = true,
|
||||||
|
only_current_line = false,
|
||||||
|
show_parameter_hints = true,
|
||||||
|
parameter_hints_prefix = "<-",
|
||||||
|
}
|
||||||
|
},
|
||||||
|
server = {
|
||||||
|
on_attach = on_attach,
|
||||||
|
capabilities = capabilities,
|
||||||
|
flags = lsp_flags,
|
||||||
|
settings = {
|
||||||
|
["rust_analyzer"] = {
|
||||||
|
checkOnSave = {
|
||||||
|
command = "clippy"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
require('rust-tools').setup(rustToolsOpts)
|
||||||
|
--on_attach = on_attach,
|
||||||
|
--flags = lsp_flags,
|
||||||
|
require('lspconfig')['rust_analyzer'].setup {
|
||||||
on_attach = on_attach,
|
on_attach = on_attach,
|
||||||
flags = lsp_flags,
|
flags = lsp_flags,
|
||||||
|
-- server-specific settings...
|
||||||
|
settings = {
|
||||||
|
["rust-analyzer"] = {}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
end,
|
end,
|
||||||
['sumneko_lua'] = function()
|
['sumneko_lua'] = function()
|
||||||
@ -63,11 +96,11 @@ require('mason-lspconfig').setup_handlers {
|
|||||||
}
|
}
|
||||||
end,
|
end,
|
||||||
}
|
}
|
||||||
require('lspconfig')['rust_analyzer'].setup {
|
--require('lspconfig')['rust_analyzer'].setup {
|
||||||
on_attach = on_attach,
|
-- on_attach = on_attach,
|
||||||
flags = lsp_flags,
|
-- flags = lsp_flags,
|
||||||
-- Server-specific settings...
|
-- -- Server-specific settings...
|
||||||
settings = {
|
-- settings = {
|
||||||
["rust-analyzer"] = {}
|
-- ["rust-analyzer"] = {}
|
||||||
}
|
-- }
|
||||||
}
|
--}
|
||||||
|
@ -25,8 +25,12 @@ require("packer").startup(function(use)
|
|||||||
"kosayoda/nvim-lightbulb",
|
"kosayoda/nvim-lightbulb",
|
||||||
})
|
})
|
||||||
use("hrsh7th/cmp-nvim-lsp")
|
use("hrsh7th/cmp-nvim-lsp")
|
||||||
|
use("hrsh7th/cmp-nvim-lsp-signature-help")
|
||||||
|
use("hrsh7th/cmp-nvim-lua")
|
||||||
use("hrsh7th/cmp-buffer")
|
use("hrsh7th/cmp-buffer")
|
||||||
use("hrsh7th/cmp-path")
|
use("hrsh7th/cmp-path")
|
||||||
|
use("hrsh7th/cmp-vsnip")
|
||||||
|
use("hrsh7th/vim-vsnip")
|
||||||
use("hrsh7th/nvim-cmp")
|
use("hrsh7th/nvim-cmp")
|
||||||
use("hrsh7th/cmp-cmdline")
|
use("hrsh7th/cmp-cmdline")
|
||||||
use("saadparwaiz1/cmp_luasnip")
|
use("saadparwaiz1/cmp_luasnip")
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
require"toggleterm".setup{
|
require"toggleterm".setup{
|
||||||
open_mapping = [[<c-y>]],
|
open_mapping = [[<c-y>]],
|
||||||
hide_numbers = true,
|
hide_numbers = true,
|
||||||
direction = 'float',
|
--direction = 'float',
|
||||||
float_opts = {
|
float_opts = {
|
||||||
border = 'curved'
|
border = 'curved'
|
||||||
},
|
},
|
||||||
@ -9,3 +9,5 @@ require"toggleterm".setup{
|
|||||||
enabled = false
|
enabled = false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user