384 lines
11 KiB
Lua
384 lines
11 KiB
Lua
--[[
|
|
|
|
=====================================================================
|
|
==================== READ THIS BEFORE CONTINUING ====================
|
|
=====================================================================
|
|
|
|
Kickstart.nvim is *not* a distribution.
|
|
|
|
Kickstart.nvim is a template for your own configuration.
|
|
The goal is that you can read every line of code, top-to-bottom, and understand
|
|
what your configuration is doing.
|
|
|
|
Once you've done that, you should start exploring, configuring and tinkering to
|
|
explore Neovim!
|
|
|
|
If you don't know anything about Lua, I recommend taking some time to read through
|
|
a guide. One possible example:
|
|
- https://learnxinyminutes.com/docs/lua/
|
|
|
|
And then you can explore or search through `:help lua-guide`
|
|
|
|
|
|
Kickstart Guide:
|
|
|
|
I have left several `:help X` comments throughout the init.lua
|
|
You should run that command and read that help section for more information.
|
|
|
|
In addition, I have some `NOTE:` items throughout the file.
|
|
These are for you, the reader to help understand what is happening. Feel free to delete
|
|
them once you know what you're doing, but they should serve as a guide for when you
|
|
are first encountering a few different constructs in your nvim config.
|
|
|
|
I hope you enjoy your Neovim journey,
|
|
- TJ
|
|
|
|
P.S. You can delete this when you're done too. It's your config now :)
|
|
--]]
|
|
-- Set <space> as the leader key
|
|
-- See `:help mapleader`
|
|
-- NOTE: Must happen before plugins are required (otherwise wrong leader will be used)
|
|
vim.g.mapleader = ' '
|
|
vim.g.maplocalleader = ' '
|
|
|
|
-- Install package manager
|
|
-- https://github.com/folke/lazy.nvim
|
|
-- `:help lazy.nvim.txt` for more info
|
|
local lazypath = vim.fn.stdpath 'data' .. '/lazy/lazy.nvim'
|
|
if not vim.loop.fs_stat(lazypath) then
|
|
vim.fn.system {
|
|
'git',
|
|
'clone',
|
|
'--filter=blob:none',
|
|
'https://github.com/folke/lazy.nvim.git',
|
|
'--branch=stable', -- latest stable release
|
|
lazypath,
|
|
}
|
|
end
|
|
vim.opt.rtp:prepend(lazypath)
|
|
|
|
require('custom.plugins')
|
|
require('custom.key_maps')
|
|
require('custom.autocmd')
|
|
require('custom.leader_shortcuts')
|
|
require('custom.treesitter')
|
|
require('custom.which_key')
|
|
|
|
-- [[ Setting options ]]
|
|
-- See `:help vim.o`
|
|
|
|
-- Set highlight on search
|
|
vim.o.hlsearch = false
|
|
|
|
-- Make line numbers default
|
|
vim.wo.number = true
|
|
|
|
-- Enable mouse mode
|
|
vim.o.mouse = 'a'
|
|
|
|
-- Sync clipboard between OS and Neovim.
|
|
-- Remove this option if you want your OS clipboard to remain independent.
|
|
-- See `:help 'clipboard'`
|
|
vim.o.clipboard = 'unnamedplus'
|
|
|
|
-- Enable break indent
|
|
vim.o.breakindent = true
|
|
|
|
-- Save undo history
|
|
vim.o.undofile = true
|
|
|
|
-- Case insensitive searching UNLESS /C or capital in search
|
|
vim.o.ignorecase = true
|
|
vim.o.smartcase = true
|
|
|
|
-- Keep signcolumn on by default
|
|
vim.wo.signcolumn = 'yes'
|
|
|
|
-- Decrease update time
|
|
vim.o.updatetime = 250
|
|
vim.o.timeout = true
|
|
vim.o.timeoutlen = 300
|
|
|
|
-- Set completeopt to have a better completion experience
|
|
vim.o.completeopt = 'menuone,noselect'
|
|
|
|
-- NOTE: You should make sure your terminal supports this
|
|
vim.o.termguicolors = true
|
|
|
|
--- Autocommands
|
|
|
|
-- [[ Highlight on yank ]]
|
|
-- See `:help vim.highlight.on_yank()`
|
|
local highlight_group = vim.api.nvim_create_augroup('YankHighlight', { clear = true })
|
|
vim.api.nvim_create_autocmd('TextYankPost', {
|
|
callback = function()
|
|
vim.highlight.on_yank()
|
|
end,
|
|
group = highlight_group,
|
|
pattern = '*',
|
|
})
|
|
|
|
-- [[ Configure Telescope ]]
|
|
-- See `:help telescope` and `:help telescope.setup()`
|
|
require('telescope').setup {
|
|
defaults = {
|
|
mappings = {
|
|
i = {
|
|
['<C-u>'] = false,
|
|
['<C-d>'] = false,
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
-- Enable telescope fzf native, if installed
|
|
pcall(require('telescope').load_extension, 'fzf')
|
|
require("telescope").setup {
|
|
pickers = {
|
|
live_grep = {
|
|
additional_args = function(_)
|
|
return { "--hidden" }
|
|
end
|
|
},
|
|
},
|
|
}
|
|
|
|
-- LSP settings.
|
|
-- This function gets run when an LSP connects to a particular buffer.
|
|
local on_attach = function(_, bufnr)
|
|
-- NOTE: Remember that lua is a real programming language, and as such it is possible
|
|
-- to define small helper and utility functions so you don't have to repeat yourself
|
|
-- many times.
|
|
--
|
|
-- In this case, we create a function that lets us more easily define mappings specific
|
|
-- for LSP related items. It sets the mode, buffer and description for us each time.
|
|
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>rn', vim.lsp.buf.rename, '[R]e[n]ame')
|
|
nmap('<leader>ca', vim.lsp.buf.code_action, '[C]ode [A]ction')
|
|
|
|
nmap('gd', vim.lsp.buf.definition, '[G]oto [D]efinition')
|
|
nmap('gr', require('telescope.builtin').lsp_references, '[G]oto [R]eferences')
|
|
nmap('gI', vim.lsp.buf.implementation, '[G]oto [I]mplementation')
|
|
nmap('<leader>D', vim.lsp.buf.type_definition, 'Type [D]efinition')
|
|
nmap('<leader>ds', require('telescope.builtin').lsp_document_symbols, '[D]ocument [S]ymbols')
|
|
nmap('<leader>ws', require('telescope.builtin').lsp_dynamic_workspace_symbols, '[W]orkspace [S]ymbols')
|
|
|
|
-- 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('gD', vim.lsp.buf.declaration, '[G]oto [D]eclaration')
|
|
nmap('<leader>wa', vim.lsp.buf.add_workspace_folder, '[W]orkspace [A]dd Folder')
|
|
nmap('<leader>wr', vim.lsp.buf.remove_workspace_folder, '[W]orkspace [R]emove Folder')
|
|
nmap('<leader>wl', 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
|
|
|
|
-- Enable the following language servers
|
|
-- Feel free to add/remove any LSPs that you want here. They will automatically be installed.
|
|
--
|
|
-- Add any additional override configuration in the following tables. They will be passed to
|
|
-- the `settings` field of the server config. You must look up that documentation yourself.
|
|
local servers = {
|
|
-- clangd = {},
|
|
-- gopls = {},
|
|
-- pyright = {},
|
|
-- rust_analyzer = {},
|
|
-- tsserver = {},
|
|
|
|
lua_ls = {
|
|
Lua = {
|
|
workspace = { checkThirdParty = false },
|
|
telemetry = { enable = false },
|
|
},
|
|
},
|
|
}
|
|
|
|
-- Setup neovim lua configuration
|
|
require('neodev').setup()
|
|
|
|
-- 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)
|
|
require 'cmp'.setup {
|
|
sources = {
|
|
{ name = 'path' }
|
|
}
|
|
}
|
|
|
|
-- Ensure the servers above are installed
|
|
local mason_lspconfig = require 'mason-lspconfig'
|
|
|
|
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],
|
|
}
|
|
end,
|
|
}
|
|
|
|
require 'lspconfig'.terraformls.setup {}
|
|
vim.api.nvim_create_autocmd({ "BufWritePre" }, {
|
|
callback = function()
|
|
vim.lsp.buf.format()
|
|
end,
|
|
pattern = { "*.tf", "*.tfvars" },
|
|
})
|
|
|
|
-- Configure prettier
|
|
local prettier = require("prettier")
|
|
|
|
prettier.setup({
|
|
bin = 'prettier', -- or `'prettierd'` (v0.23.3+)
|
|
filetypes = {
|
|
"css",
|
|
"graphql",
|
|
"html",
|
|
"javascript",
|
|
"javascriptreact",
|
|
"json",
|
|
"less",
|
|
"markdown",
|
|
"scss",
|
|
"typescript",
|
|
"typescriptreact",
|
|
"yaml",
|
|
},
|
|
})
|
|
|
|
|
|
-- nvim-cmp setup
|
|
local cmp = require 'cmp'
|
|
local luasnip = require 'luasnip'
|
|
|
|
luasnip.config.setup {}
|
|
|
|
cmp.setup {
|
|
snippet = {
|
|
expand = function(args)
|
|
luasnip.lsp_expand(args.body)
|
|
end,
|
|
},
|
|
mapping = cmp.mapping.preset.insert {
|
|
['<C-d>'] = cmp.mapping.scroll_docs(-4),
|
|
['<C-f>'] = cmp.mapping.scroll_docs(4),
|
|
['<C-Space>'] = cmp.mapping.complete {},
|
|
['<CR>'] = cmp.mapping.confirm {
|
|
behavior = cmp.ConfirmBehavior.Replace,
|
|
select = true,
|
|
},
|
|
['<Tab>'] = cmp.mapping(function(fallback)
|
|
if cmp.visible() then
|
|
cmp.select_next_item()
|
|
elseif luasnip.expand_or_jumpable() then
|
|
luasnip.expand_or_jump()
|
|
else
|
|
fallback()
|
|
end
|
|
end, { 'i', 's' }),
|
|
['<S-Tab>'] = cmp.mapping(function(fallback)
|
|
if cmp.visible() then
|
|
cmp.select_prev_item()
|
|
elseif luasnip.jumpable(-1) then
|
|
luasnip.jump(-1)
|
|
else
|
|
fallback()
|
|
end
|
|
end, { 'i', 's' }),
|
|
},
|
|
sources = {
|
|
{ name = 'nvim_lsp' },
|
|
{ name = 'luasnip' },
|
|
},
|
|
}
|
|
|
|
-- Setting up ghvim
|
|
require('litee.lib').setup()
|
|
require('litee.gh').setup({
|
|
-- deprecated, around for compatability for now.
|
|
jump_mode = "invoking",
|
|
-- remap the arrow keys to resize any litee.nvim windows.
|
|
map_resize_keys = false,
|
|
-- do not map any keys inside any gh.nvim buffers.
|
|
disable_keymaps = false,
|
|
-- the icon set to use.
|
|
icon_set = "default",
|
|
-- any custom icons to use.
|
|
icon_set_custom = nil,
|
|
-- whether to register the @username and #issue_number omnifunc completion
|
|
-- in buffers which start with .git/
|
|
git_buffer_completion = true,
|
|
-- defines keymaps in gh.nvim buffers.
|
|
keymaps = {
|
|
-- when inside a gh.nvim panel, this key will open a node if it has
|
|
-- any futher functionality. for example, hitting <CR> on a commit node
|
|
-- will open the commit's changed files in a new gh.nvim panel.
|
|
open = "<CR>",
|
|
-- when inside a gh.nvim panel, expand a collapsed node
|
|
expand = "zo",
|
|
-- when inside a gh.nvim panel, collpased and expanded node
|
|
collapse = "zc",
|
|
-- when cursor is over a "#1234" formatted issue or PR, open its details
|
|
-- and comments in a new tab.
|
|
goto_issue = "gd",
|
|
-- show any details about a node, typically, this reveals commit messages
|
|
-- and submitted review bodys.
|
|
details = "d",
|
|
-- inside a convo buffer, submit a comment
|
|
submit_comment = "<C-s>",
|
|
-- inside a convo buffer, when your cursor is ontop of a comment, open
|
|
-- up a set of actions that can be performed.
|
|
actions = "<C-a>",
|
|
-- inside a thread convo buffer, resolve the thread.
|
|
resolve_thread = "<C-r>",
|
|
-- inside a gh.nvim panel, if possible, open the node's web URL in your
|
|
-- browser. useful particularily for digging into external failed CI
|
|
-- checks.
|
|
goto_web = "gx"
|
|
}
|
|
})
|
|
|
|
local configs = require('lspconfig.configs')
|
|
local lspconfig = require('lspconfig')
|
|
local util = require('lspconfig.util')
|
|
|
|
if not configs.helm_ls then
|
|
configs.helm_ls = {
|
|
default_config = {
|
|
cmd = { "helm_ls", "serve" },
|
|
filetypes = { 'helm' },
|
|
root_dir = function(fname)
|
|
return util.root_pattern('Chart.yaml')(fname)
|
|
end,
|
|
},
|
|
}
|
|
end
|
|
|
|
lspconfig.helm_ls.setup {
|
|
filetypes = { "helm" },
|
|
cmd = { "helm_ls", "serve" },
|
|
}
|
|
|
|
-- The line beneath this is called `modeline`. See `:help modeline`
|
|
-- vim: ts=2 sts=2 sw=2 et
|