mirror of
https://github.com/pratiktri/dotfiles.git
synced 2026-02-04 08:41:43 +05:30
- Testing setup through neotest plugin - Spellcheck enabled on markdown and text files - Diagnosis summary through trouble plugin - Code completion keybindings improved - Auto-formatting through conform plugin - Reactjs context aware commenting through nvim-ts-context-commentstring - Auto HTML tag completion through nvim-ts-autotag - CSS color highlight through nvim-highlight-colors - Lualine: breadcrumbs, git status, single line - Auto restore neovim sessions - Better keyboard maps Shell - Aliases now load from .bashrc or .zshrc - Bash & zsh shortcuts to easy open and create projects - zoxide instead of cd when installed - bootstrap.sh shellhardened
162 lines
6.7 KiB
Lua
162 lines
6.7 KiB
Lua
-- This function gets run when an LSP connects to a particular buffer.
|
|
-- Define mappings specific for LSP related items.
|
|
-- It sets the mode, buffer and description for us each time.
|
|
local on_attach = function(_, bufnr)
|
|
local nmap = function(keys, func, desc)
|
|
if desc then
|
|
desc = "LSP: " .. desc
|
|
end
|
|
|
|
vim.keymap.set("n", keys, func, { buffer = bufnr, desc = desc })
|
|
end
|
|
|
|
nmap("<leader>cr", vim.lsp.buf.rename, "[R]e[n]ame")
|
|
nmap("<leader>ca", vim.lsp.buf.code_action, "[C]ode [A]ction")
|
|
-- See `:help K` for why this keymap
|
|
nmap("K", vim.lsp.buf.hover, "Hover Documentation")
|
|
-- nmap("<C-k>", vim.lsp.buf.signature_help, "Signature Documentation")
|
|
|
|
-- Lesser used LSP functionality
|
|
nmap("<leader>cws", require("telescope.builtin").lsp_dynamic_workspace_symbols, "[W]orkspace [S]ymbols")
|
|
nmap("<leader>cwl", function()
|
|
print(vim.inspect(vim.lsp.buf.list_workspace_folders()))
|
|
end, "[W]orkspace [L]ist Folders")
|
|
|
|
-- Create a command `:Format` local to the LSP buffer
|
|
vim.api.nvim_buf_create_user_command(bufnr, "Format", function(_)
|
|
vim.lsp.buf.format()
|
|
end, { desc = "Format current buffer with LSP" })
|
|
end
|
|
|
|
return {
|
|
{
|
|
-- LSP Configuration & Plugins
|
|
"neovim/nvim-lspconfig",
|
|
dependencies = {
|
|
-- Automatically install LSPs to stdpath for neovim
|
|
{ "williamboman/mason.nvim", config = true },
|
|
{ "williamboman/mason-lspconfig.nvim" },
|
|
|
|
-- Useful status updates for LSP
|
|
{ "j-hui/fidget.nvim", opts = {} },
|
|
|
|
{ "folke/neodev.nvim" },
|
|
},
|
|
-- WARN: DO NOT do `config` here it would override `config` from coding-formatting.lua
|
|
-- That's why we do the LSP config inside mason-lspconfig
|
|
},
|
|
|
|
{
|
|
"williamboman/mason-lspconfig.nvim",
|
|
config = function()
|
|
-- Configure LSP
|
|
|
|
-- mason-lspconfig requires that these setup functions are called in this order
|
|
-- BEFORE setting up the servers.
|
|
require("mason").setup()
|
|
local mason_lspconfig = require("mason-lspconfig")
|
|
mason_lspconfig.setup()
|
|
|
|
-- Enable the following language servers
|
|
-- Add any additional override configuration in the following tables. They will be passed to the `settings` field of the server config
|
|
-- If you want to override the default filetypes that your language server will attach to you can define the property 'filetypes' to the map in question.
|
|
local servers = {
|
|
-- clangd = {},
|
|
-- gopls = {},
|
|
|
|
lua_ls = {
|
|
Lua = {
|
|
workspace = { checkThirdParty = false },
|
|
telemetry = { enable = false },
|
|
-- hint = { enable = true },
|
|
-- NOTE: toggle below to ignore Lua_LS's noisy `missing-fields` warnings
|
|
-- diagnostics = { disable = { 'missing-fields' } },
|
|
},
|
|
},
|
|
|
|
-- Markdown
|
|
marksman = {},
|
|
|
|
awk_ls = {},
|
|
bashls = {
|
|
filetypes = { "sh", "bash", "zsh" },
|
|
},
|
|
cssls = {},
|
|
dockerls = {},
|
|
docker_compose_language_service = {},
|
|
html = { filetypes = { 'html', 'twig', 'hbs' } },
|
|
jsonls = {},
|
|
pyright = {},
|
|
rust_analyzer = {},
|
|
tsserver = {
|
|
typescript = {
|
|
inlayHints = {
|
|
-- includeInlayParameterNameHints = 'all',
|
|
includeInlayParameterNameHintsWhenArgumentMatchesName = false,
|
|
includeInlayFunctionParameterTypeHints = true,
|
|
includeInlayVariableTypeHints = true,
|
|
includeInlayVariableTypeHintsWhenTypeMatchesName = false,
|
|
includeInlayPropertyDeclarationTypeHints = true,
|
|
includeInlayFunctionLikeReturnTypeHints = true,
|
|
includeInlayEnumMemberValueHints = true,
|
|
}
|
|
},
|
|
javascript = {
|
|
inlayHints = {
|
|
-- includeInlayParameterNameHints = 'all',
|
|
includeInlayParameterNameHintsWhenArgumentMatchesName = false,
|
|
includeInlayFunctionParameterTypeHints = true,
|
|
includeInlayVariableTypeHints = true,
|
|
includeInlayVariableTypeHintsWhenTypeMatchesName = false,
|
|
includeInlayPropertyDeclarationTypeHints = true,
|
|
includeInlayFunctionLikeReturnTypeHints = true,
|
|
includeInlayEnumMemberValueHints = true,
|
|
}
|
|
}
|
|
},
|
|
}
|
|
|
|
-- nvim-cmp supports additional completion capabilities, so broadcast that to servers
|
|
local capabilities = vim.lsp.protocol.make_client_capabilities()
|
|
capabilities = require("cmp_nvim_lsp").default_capabilities(capabilities)
|
|
|
|
mason_lspconfig.setup({
|
|
ensure_installed = vim.tbl_keys(servers),
|
|
})
|
|
|
|
mason_lspconfig.setup_handlers({
|
|
function(server_name)
|
|
require("lspconfig")[server_name].setup({
|
|
capabilities = capabilities,
|
|
on_attach = on_attach,
|
|
settings = servers[server_name],
|
|
filetypes = (servers[server_name] or {}).filetypes,
|
|
})
|
|
end,
|
|
})
|
|
end,
|
|
},
|
|
|
|
{
|
|
"j-hui/fidget.nvim",
|
|
opts = {
|
|
progress = {
|
|
poll_rate = 1, -- How and when to poll for progress messages
|
|
suppress_on_insert = true, -- Suppress new messages while in insert mode
|
|
ignore_done_already = true, -- Ignore new tasks that are already complete
|
|
ignore_empty_message = true, -- Ignore new tasks that don't contain a message
|
|
ignore = {}, -- List of LSP servers to ignore
|
|
|
|
display = {
|
|
render_limit = 1, -- How many LSP messages to show at once
|
|
skip_history = true, -- Whether progress notifications should be omitted from history
|
|
},
|
|
},
|
|
|
|
notification = {
|
|
filter = vim.log.levels.WARN, -- Minimum notifications level
|
|
},
|
|
},
|
|
},
|
|
}
|