style(init): Move everything inside config
This commit is contained in:
		
							parent
							
								
									23d84a8a99
								
							
						
					
					
						commit
						6215c8b7ba
					
				
							
								
								
									
										662
									
								
								init.lua
								
								
								
								
							
							
						
						
									
										662
									
								
								init.lua
								
								
								
								
							| 
						 | 
					@ -93,6 +93,108 @@ require('lazy').setup({
 | 
				
			||||||
      -- Additional lua configuration, makes nvim stuff amazing!
 | 
					      -- Additional lua configuration, makes nvim stuff amazing!
 | 
				
			||||||
      'folke/neodev.nvim',
 | 
					      'folke/neodev.nvim',
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    config = function()
 | 
				
			||||||
 | 
					      -- [[ Configure LSP ]]
 | 
				
			||||||
 | 
					      --  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') Use keys to lazy load plugin(telescope-ui)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        nmap('gd', require('telescope.builtin').lsp_definitions, '[G]oto [D]efinition')
 | 
				
			||||||
 | 
					        nmap('gr', require('telescope.builtin').lsp_references, '[G]oto [R]eferences')
 | 
				
			||||||
 | 
					        nmap('gI', require('telescope.builtin').lsp_implementations, '[G]oto [I]mplementation')
 | 
				
			||||||
 | 
					        nmap('<leader>D', require('telescope.builtin').lsp_type_definitions, '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
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      -- mason-lspconfig requires that these setup functions are called in this order
 | 
				
			||||||
 | 
					      -- before setting up the servers.
 | 
				
			||||||
 | 
					      require('mason').setup()
 | 
				
			||||||
 | 
					      require('mason-lspconfig').setup()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      -- 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.
 | 
				
			||||||
 | 
					      --
 | 
				
			||||||
 | 
					      --  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 = {},
 | 
				
			||||||
 | 
					        -- pyright = {},
 | 
				
			||||||
 | 
					        rust_analyzer = {},
 | 
				
			||||||
 | 
					        tsserver = {},
 | 
				
			||||||
 | 
					        html = { filetypes = { 'html', 'twig', 'hbs' } },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        lua_ls = {
 | 
				
			||||||
 | 
					          Lua = {
 | 
				
			||||||
 | 
					            workspace = { checkThirdParty = false },
 | 
				
			||||||
 | 
					            telemetry = { enable = false },
 | 
				
			||||||
 | 
					            -- NOTE: toggle below to ignore Lua_LS's noisy `missing-fields` warnings
 | 
				
			||||||
 | 
					            -- diagnostics = { disable = { 'missing-fields' } },
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      -- 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)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      -- 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],
 | 
				
			||||||
 | 
					            filetypes = (servers[server_name] or {}).filetypes,
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        end,
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    end,
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  {
 | 
					  {
 | 
				
			||||||
| 
						 | 
					@ -110,10 +212,86 @@ require('lazy').setup({
 | 
				
			||||||
      -- Adds a number of user-friendly snippets
 | 
					      -- Adds a number of user-friendly snippets
 | 
				
			||||||
      'rafamadriz/friendly-snippets',
 | 
					      'rafamadriz/friendly-snippets',
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    config = function()
 | 
				
			||||||
 | 
					      -- [[ Configure nvim-cmp ]]
 | 
				
			||||||
 | 
					      -- See `:help cmp`
 | 
				
			||||||
 | 
					      local cmp = require 'cmp'
 | 
				
			||||||
 | 
					      local luasnip = require 'luasnip'
 | 
				
			||||||
 | 
					      require('luasnip.loaders.from_vscode').lazy_load()
 | 
				
			||||||
 | 
					      luasnip.config.setup {}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      cmp.setup {
 | 
				
			||||||
 | 
					        snippet = {
 | 
				
			||||||
 | 
					          expand = function(args)
 | 
				
			||||||
 | 
					            luasnip.lsp_expand(args.body)
 | 
				
			||||||
 | 
					          end,
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        completion = {
 | 
				
			||||||
 | 
					          completeopt = 'menu,menuone,noinsert',
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        mapping = cmp.mapping.preset.insert {
 | 
				
			||||||
 | 
					          ['<C-n>'] = cmp.mapping.select_next_item(),
 | 
				
			||||||
 | 
					          ['<C-p>'] = cmp.mapping.select_prev_item(),
 | 
				
			||||||
 | 
					          ['<C-b>'] = 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_locally_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.locally_jumpable(-1) then
 | 
				
			||||||
 | 
					              luasnip.jump(-1)
 | 
				
			||||||
 | 
					            else
 | 
				
			||||||
 | 
					              fallback()
 | 
				
			||||||
 | 
					            end
 | 
				
			||||||
 | 
					          end, { 'i', 's' }),
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        sources = {
 | 
				
			||||||
 | 
					          { name = 'nvim_lsp' },
 | 
				
			||||||
 | 
					          { name = 'luasnip' },
 | 
				
			||||||
 | 
					          { name = 'path' },
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    end,
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  -- Useful plugin to show you pending keybinds.
 | 
					  -- Useful plugin to show you pending keybinds.
 | 
				
			||||||
  { 'folke/which-key.nvim',  opts = {} },
 | 
					  {
 | 
				
			||||||
 | 
					    'folke/which-key.nvim',
 | 
				
			||||||
 | 
					    opts = {},
 | 
				
			||||||
 | 
					    config = function()
 | 
				
			||||||
 | 
					      -- document existing key chains
 | 
				
			||||||
 | 
					      require('which-key').register {
 | 
				
			||||||
 | 
					        ['<leader>c'] = { name = '[C]ode', _ = 'which_key_ignore' },
 | 
				
			||||||
 | 
					        ['<leader>d'] = { name = '[D]ocument', _ = 'which_key_ignore' },
 | 
				
			||||||
 | 
					        ['<leader>g'] = { name = '[G]it', _ = 'which_key_ignore' },
 | 
				
			||||||
 | 
					        ['<leader>h'] = { name = 'Git [H]unk', _ = 'which_key_ignore' },
 | 
				
			||||||
 | 
					        ['<leader>r'] = { name = '[R]ename', _ = 'which_key_ignore' },
 | 
				
			||||||
 | 
					        ['<leader>s'] = { name = '[S]earch', _ = 'which_key_ignore' },
 | 
				
			||||||
 | 
					        ['<leader>t'] = { name = '[T]oggle', _ = 'which_key_ignore' },
 | 
				
			||||||
 | 
					        ['<leader>w'] = { name = '[W]orkspace', _ = 'which_key_ignore' },
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      -- register which-key VISUAL mode
 | 
				
			||||||
 | 
					      -- required for visual <leader>hs (hunk stage) to work
 | 
				
			||||||
 | 
					      require('which-key').register({
 | 
				
			||||||
 | 
					        ['<leader>'] = { name = 'VISUAL <leader>' },
 | 
				
			||||||
 | 
					        ['<leader>h'] = { 'Git [H]unk' },
 | 
				
			||||||
 | 
					      }, { mode = 'v' })
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  {
 | 
					  {
 | 
				
			||||||
    -- Adds git related signs to the gutter, as well as utilities for managing changes
 | 
					    -- Adds git related signs to the gutter, as well as utilities for managing changes
 | 
				
			||||||
    'lewis6991/gitsigns.nvim',
 | 
					    'lewis6991/gitsigns.nvim',
 | 
				
			||||||
| 
						 | 
					@ -196,7 +374,7 @@ require('lazy').setup({
 | 
				
			||||||
    opts = {
 | 
					    opts = {
 | 
				
			||||||
      options = {
 | 
					      options = {
 | 
				
			||||||
        icons_enabled = true,
 | 
					        icons_enabled = true,
 | 
				
			||||||
        -- theme = 'auto',
 | 
					        theme = 'auto',
 | 
				
			||||||
        component_separators = '/',
 | 
					        component_separators = '/',
 | 
				
			||||||
        section_separators = '',
 | 
					        section_separators = '',
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
| 
						 | 
					@ -237,6 +415,93 @@ require('lazy').setup({
 | 
				
			||||||
        end,
 | 
					        end,
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    config = function()
 | 
				
			||||||
 | 
					      -- [[ 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')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      -- Telescope live_grep in git root
 | 
				
			||||||
 | 
					      -- Function to find the git root directory based on the current buffer's path
 | 
				
			||||||
 | 
					      local function find_git_root()
 | 
				
			||||||
 | 
					        -- Use the current buffer's path as the starting point for the git search
 | 
				
			||||||
 | 
					        local current_file = vim.api.nvim_buf_get_name(0)
 | 
				
			||||||
 | 
					        local current_dir
 | 
				
			||||||
 | 
					        local cwd = vim.fn.getcwd()
 | 
				
			||||||
 | 
					        -- If the buffer is not associated with a file, return nil
 | 
				
			||||||
 | 
					        if current_file == '' then
 | 
				
			||||||
 | 
					          current_dir = cwd
 | 
				
			||||||
 | 
					        else
 | 
				
			||||||
 | 
					          -- Extract the directory from the current file's path
 | 
				
			||||||
 | 
					          current_dir = vim.fn.fnamemodify(current_file, ':h')
 | 
				
			||||||
 | 
					        end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        -- Find the Git root directory from the current file's path
 | 
				
			||||||
 | 
					        local git_root = vim.fn.systemlist('git -C ' ..
 | 
				
			||||||
 | 
					              vim.fn.escape(current_dir, ' ') .. ' rev-parse --show-toplevel')
 | 
				
			||||||
 | 
					            [1]
 | 
				
			||||||
 | 
					        if vim.v.shell_error ~= 0 then
 | 
				
			||||||
 | 
					          print 'Not a git repository. Searching on current working directory'
 | 
				
			||||||
 | 
					          return cwd
 | 
				
			||||||
 | 
					        end
 | 
				
			||||||
 | 
					        return git_root
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      -- Custom live_grep function to search in git root
 | 
				
			||||||
 | 
					      local function live_grep_git_root()
 | 
				
			||||||
 | 
					        local git_root = find_git_root()
 | 
				
			||||||
 | 
					        if git_root then
 | 
				
			||||||
 | 
					          require('telescope.builtin').live_grep {
 | 
				
			||||||
 | 
					            search_dirs = { git_root },
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        end
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      vim.api.nvim_create_user_command('LiveGrepGitRoot', live_grep_git_root, {})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      -- See `:help telescope.builtin`
 | 
				
			||||||
 | 
					      vim.keymap.set('n', '<leader>?', require('telescope.builtin').oldfiles,
 | 
				
			||||||
 | 
					        { desc = '[?] Find recently opened files' })
 | 
				
			||||||
 | 
					      vim.keymap.set('n', '<leader><space>', require('telescope.builtin').buffers,
 | 
				
			||||||
 | 
					        { desc = '[ ] Find existing buffers' })
 | 
				
			||||||
 | 
					      vim.keymap.set('n', '<leader>/', function()
 | 
				
			||||||
 | 
					        -- You can pass additional configuration to telescope to change theme, layout, etc.
 | 
				
			||||||
 | 
					        require('telescope.builtin').current_buffer_fuzzy_find(require('telescope.themes').get_dropdown {
 | 
				
			||||||
 | 
					          winblend = 10,
 | 
				
			||||||
 | 
					          previewer = false,
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					      end, { desc = '[/] Fuzzily search in current buffer' })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      local function telescope_live_grep_open_files()
 | 
				
			||||||
 | 
					        require('telescope.builtin').live_grep {
 | 
				
			||||||
 | 
					          grep_open_files = true,
 | 
				
			||||||
 | 
					          prompt_title = 'Live Grep in Open Files',
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      end
 | 
				
			||||||
 | 
					      vim.keymap.set('n', '<leader>s/', telescope_live_grep_open_files, { desc = '[S]earch [/] in Open Files' })
 | 
				
			||||||
 | 
					      vim.keymap.set('n', '<leader>ss', require('telescope.builtin').builtin,
 | 
				
			||||||
 | 
					        { desc = '[S]earch [S]elect Telescope' })
 | 
				
			||||||
 | 
					      vim.keymap.set('n', '<leader>gf', require('telescope.builtin').git_files, { desc = 'Search [G]it [F]iles' })
 | 
				
			||||||
 | 
					      vim.keymap.set('n', '<leader>sf', require('telescope.builtin').find_files, { desc = '[S]earch [F]iles' })
 | 
				
			||||||
 | 
					      vim.keymap.set('n', '<leader>sh', require('telescope.builtin').help_tags, { desc = '[S]earch [H]elp' })
 | 
				
			||||||
 | 
					      vim.keymap.set('n', '<leader>sw', require('telescope.builtin').grep_string,
 | 
				
			||||||
 | 
					        { desc = '[S]earch current [W]ord' })
 | 
				
			||||||
 | 
					      vim.keymap.set('n', '<leader>sg', require('telescope.builtin').live_grep, { desc = '[S]earch by [G]rep' })
 | 
				
			||||||
 | 
					      vim.keymap.set('n', '<leader>sG', ':LiveGrepGitRoot<cr>', { desc = '[S]earch by [G]rep on Git Root' })
 | 
				
			||||||
 | 
					      vim.keymap.set('n', '<leader>sd', require('telescope.builtin').diagnostics, { desc = '[S]earch [D]iagnostics' })
 | 
				
			||||||
 | 
					      vim.keymap.set('n', '<leader>sr', require('telescope.builtin').resume, { desc = '[S]earch [R]esume' })
 | 
				
			||||||
 | 
					    end,
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  {
 | 
					  {
 | 
				
			||||||
| 
						 | 
					@ -248,7 +513,77 @@ require('lazy').setup({
 | 
				
			||||||
    build = ':TSUpdate',
 | 
					    build = ':TSUpdate',
 | 
				
			||||||
    config = function()
 | 
					    config = function()
 | 
				
			||||||
      require 'nvim-treesitter.install'.compilers = { 'zig' }
 | 
					      require 'nvim-treesitter.install'.compilers = { 'zig' }
 | 
				
			||||||
    end
 | 
					
 | 
				
			||||||
 | 
					      -- [[ Configure Treesitter ]]
 | 
				
			||||||
 | 
					      -- See `:help nvim-treesitter`
 | 
				
			||||||
 | 
					      -- Defer Treesitter setup after first render to improve startup time of 'nvim {filename}'
 | 
				
			||||||
 | 
					      vim.defer_fn(function()
 | 
				
			||||||
 | 
					        require('nvim-treesitter.configs').setup {
 | 
				
			||||||
 | 
					          -- Add languages to be installed here that you want installed for treesitter
 | 
				
			||||||
 | 
					          ensure_installed = { 'c', 'cpp', 'go', 'lua', 'python', 'rust', 'tsx', 'javascript', 'typescript', 'vimdoc', 'vim', 'bash', 'markdown', 'html', 'css' },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					          -- Autoinstall languages that are not installed. Defaults to false (but you can change for yourself!)
 | 
				
			||||||
 | 
					          auto_install = false,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					          highlight = { enable = true },
 | 
				
			||||||
 | 
					          indent = { enable = true },
 | 
				
			||||||
 | 
					          incremental_selection = {
 | 
				
			||||||
 | 
					            enable = true,
 | 
				
			||||||
 | 
					            keymaps = {
 | 
				
			||||||
 | 
					              init_selection = '<c-space>',
 | 
				
			||||||
 | 
					              node_incremental = '<c-space>',
 | 
				
			||||||
 | 
					              scope_incremental = '<c-s>',
 | 
				
			||||||
 | 
					              node_decremental = '<M-space>',
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					          textobjects = {
 | 
				
			||||||
 | 
					            select = {
 | 
				
			||||||
 | 
					              enable = true,
 | 
				
			||||||
 | 
					              lookahead = true, -- Automatically jump forward to textobj, similar to targets.vim
 | 
				
			||||||
 | 
					              keymaps = {
 | 
				
			||||||
 | 
					                -- You can use the capture groups defined in textobjects.scm
 | 
				
			||||||
 | 
					                ['aa'] = '@parameter.outer',
 | 
				
			||||||
 | 
					                ['ia'] = '@parameter.inner',
 | 
				
			||||||
 | 
					                ['af'] = '@function.outer',
 | 
				
			||||||
 | 
					                ['if'] = '@function.inner',
 | 
				
			||||||
 | 
					                ['ac'] = '@class.outer',
 | 
				
			||||||
 | 
					                ['ic'] = '@class.inner',
 | 
				
			||||||
 | 
					              },
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            move = {
 | 
				
			||||||
 | 
					              enable = true,
 | 
				
			||||||
 | 
					              set_jumps = true, -- whether to set jumps in the jumplist
 | 
				
			||||||
 | 
					              goto_next_start = {
 | 
				
			||||||
 | 
					                [']m'] = '@function.outer',
 | 
				
			||||||
 | 
					                [']]'] = '@class.outer',
 | 
				
			||||||
 | 
					              },
 | 
				
			||||||
 | 
					              goto_next_end = {
 | 
				
			||||||
 | 
					                [']M'] = '@function.outer',
 | 
				
			||||||
 | 
					                [']['] = '@class.outer',
 | 
				
			||||||
 | 
					              },
 | 
				
			||||||
 | 
					              goto_previous_start = {
 | 
				
			||||||
 | 
					                ['[m'] = '@function.outer',
 | 
				
			||||||
 | 
					                ['[['] = '@class.outer',
 | 
				
			||||||
 | 
					              },
 | 
				
			||||||
 | 
					              goto_previous_end = {
 | 
				
			||||||
 | 
					                ['[M'] = '@function.outer',
 | 
				
			||||||
 | 
					                ['[]'] = '@class.outer',
 | 
				
			||||||
 | 
					              },
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            swap = {
 | 
				
			||||||
 | 
					              enable = true,
 | 
				
			||||||
 | 
					              swap_next = {
 | 
				
			||||||
 | 
					                ['<leader>a'] = '@parameter.inner',
 | 
				
			||||||
 | 
					              },
 | 
				
			||||||
 | 
					              swap_previous = {
 | 
				
			||||||
 | 
					                ['<leader>A'] = '@parameter.inner',
 | 
				
			||||||
 | 
					              },
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					          },
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      end, 0)
 | 
				
			||||||
 | 
					    end,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  -- NOTE: Next Step on Your Neovim Journey: Add/Configure additional "plugins" for kickstart
 | 
					  -- NOTE: Next Step on Your Neovim Journey: Add/Configure additional "plugins" for kickstart
 | 
				
			||||||
| 
						 | 
					@ -334,326 +669,5 @@ vim.api.nvim_create_autocmd('TextYankPost', {
 | 
				
			||||||
  pattern = '*',
 | 
					  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')
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- Telescope live_grep in git root
 | 
					 | 
				
			||||||
-- Function to find the git root directory based on the current buffer's path
 | 
					 | 
				
			||||||
local function find_git_root()
 | 
					 | 
				
			||||||
  -- Use the current buffer's path as the starting point for the git search
 | 
					 | 
				
			||||||
  local current_file = vim.api.nvim_buf_get_name(0)
 | 
					 | 
				
			||||||
  local current_dir
 | 
					 | 
				
			||||||
  local cwd = vim.fn.getcwd()
 | 
					 | 
				
			||||||
  -- If the buffer is not associated with a file, return nil
 | 
					 | 
				
			||||||
  if current_file == '' then
 | 
					 | 
				
			||||||
    current_dir = cwd
 | 
					 | 
				
			||||||
  else
 | 
					 | 
				
			||||||
    -- Extract the directory from the current file's path
 | 
					 | 
				
			||||||
    current_dir = vim.fn.fnamemodify(current_file, ':h')
 | 
					 | 
				
			||||||
  end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  -- Find the Git root directory from the current file's path
 | 
					 | 
				
			||||||
  local git_root = vim.fn.systemlist('git -C ' .. vim.fn.escape(current_dir, ' ') .. ' rev-parse --show-toplevel')
 | 
					 | 
				
			||||||
      [1]
 | 
					 | 
				
			||||||
  if vim.v.shell_error ~= 0 then
 | 
					 | 
				
			||||||
    print 'Not a git repository. Searching on current working directory'
 | 
					 | 
				
			||||||
    return cwd
 | 
					 | 
				
			||||||
  end
 | 
					 | 
				
			||||||
  return git_root
 | 
					 | 
				
			||||||
end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- Custom live_grep function to search in git root
 | 
					 | 
				
			||||||
local function live_grep_git_root()
 | 
					 | 
				
			||||||
  local git_root = find_git_root()
 | 
					 | 
				
			||||||
  if git_root then
 | 
					 | 
				
			||||||
    require('telescope.builtin').live_grep {
 | 
					 | 
				
			||||||
      search_dirs = { git_root },
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
  end
 | 
					 | 
				
			||||||
end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
vim.api.nvim_create_user_command('LiveGrepGitRoot', live_grep_git_root, {})
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- See `:help telescope.builtin`
 | 
					 | 
				
			||||||
vim.keymap.set('n', '<leader>?', require('telescope.builtin').oldfiles, { desc = '[?] Find recently opened files' })
 | 
					 | 
				
			||||||
vim.keymap.set('n', '<leader><space>', require('telescope.builtin').buffers, { desc = '[ ] Find existing buffers' })
 | 
					 | 
				
			||||||
vim.keymap.set('n', '<leader>/', function()
 | 
					 | 
				
			||||||
  -- You can pass additional configuration to telescope to change theme, layout, etc.
 | 
					 | 
				
			||||||
  require('telescope.builtin').current_buffer_fuzzy_find(require('telescope.themes').get_dropdown {
 | 
					 | 
				
			||||||
    winblend = 10,
 | 
					 | 
				
			||||||
    previewer = false,
 | 
					 | 
				
			||||||
  })
 | 
					 | 
				
			||||||
end, { desc = '[/] Fuzzily search in current buffer' })
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
local function telescope_live_grep_open_files()
 | 
					 | 
				
			||||||
  require('telescope.builtin').live_grep {
 | 
					 | 
				
			||||||
    grep_open_files = true,
 | 
					 | 
				
			||||||
    prompt_title = 'Live Grep in Open Files',
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
end
 | 
					 | 
				
			||||||
vim.keymap.set('n', '<leader>s/', telescope_live_grep_open_files, { desc = '[S]earch [/] in Open Files' })
 | 
					 | 
				
			||||||
vim.keymap.set('n', '<leader>ss', require('telescope.builtin').builtin, { desc = '[S]earch [S]elect Telescope' })
 | 
					 | 
				
			||||||
vim.keymap.set('n', '<leader>gf', require('telescope.builtin').git_files, { desc = 'Search [G]it [F]iles' })
 | 
					 | 
				
			||||||
vim.keymap.set('n', '<leader>sf', require('telescope.builtin').find_files, { desc = '[S]earch [F]iles' })
 | 
					 | 
				
			||||||
vim.keymap.set('n', '<leader>sh', require('telescope.builtin').help_tags, { desc = '[S]earch [H]elp' })
 | 
					 | 
				
			||||||
vim.keymap.set('n', '<leader>sw', require('telescope.builtin').grep_string, { desc = '[S]earch current [W]ord' })
 | 
					 | 
				
			||||||
vim.keymap.set('n', '<leader>sg', require('telescope.builtin').live_grep, { desc = '[S]earch by [G]rep' })
 | 
					 | 
				
			||||||
vim.keymap.set('n', '<leader>sG', ':LiveGrepGitRoot<cr>', { desc = '[S]earch by [G]rep on Git Root' })
 | 
					 | 
				
			||||||
vim.keymap.set('n', '<leader>sd', require('telescope.builtin').diagnostics, { desc = '[S]earch [D]iagnostics' })
 | 
					 | 
				
			||||||
vim.keymap.set('n', '<leader>sr', require('telescope.builtin').resume, { desc = '[S]earch [R]esume' })
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- [[ Configure Treesitter ]]
 | 
					 | 
				
			||||||
-- See `:help nvim-treesitter`
 | 
					 | 
				
			||||||
-- Defer Treesitter setup after first render to improve startup time of 'nvim {filename}'
 | 
					 | 
				
			||||||
vim.defer_fn(function()
 | 
					 | 
				
			||||||
  require('nvim-treesitter.configs').setup {
 | 
					 | 
				
			||||||
    -- Add languages to be installed here that you want installed for treesitter
 | 
					 | 
				
			||||||
    ensure_installed = { 'c', 'cpp', 'go', 'lua', 'python', 'rust', 'tsx', 'javascript', 'typescript', 'vimdoc', 'vim', 'bash', 'markdown', 'html', 'css' },
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    -- Autoinstall languages that are not installed. Defaults to false (but you can change for yourself!)
 | 
					 | 
				
			||||||
    auto_install = true,
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    highlight = { enable = true },
 | 
					 | 
				
			||||||
    indent = { enable = true },
 | 
					 | 
				
			||||||
    incremental_selection = {
 | 
					 | 
				
			||||||
      enable = true,
 | 
					 | 
				
			||||||
      keymaps = {
 | 
					 | 
				
			||||||
        init_selection = '<c-space>',
 | 
					 | 
				
			||||||
        node_incremental = '<c-space>',
 | 
					 | 
				
			||||||
        scope_incremental = '<c-s>',
 | 
					 | 
				
			||||||
        node_decremental = '<M-space>',
 | 
					 | 
				
			||||||
      },
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    textobjects = {
 | 
					 | 
				
			||||||
      select = {
 | 
					 | 
				
			||||||
        enable = true,
 | 
					 | 
				
			||||||
        lookahead = true, -- Automatically jump forward to textobj, similar to targets.vim
 | 
					 | 
				
			||||||
        keymaps = {
 | 
					 | 
				
			||||||
          -- You can use the capture groups defined in textobjects.scm
 | 
					 | 
				
			||||||
          ['aa'] = '@parameter.outer',
 | 
					 | 
				
			||||||
          ['ia'] = '@parameter.inner',
 | 
					 | 
				
			||||||
          ['af'] = '@function.outer',
 | 
					 | 
				
			||||||
          ['if'] = '@function.inner',
 | 
					 | 
				
			||||||
          ['ac'] = '@class.outer',
 | 
					 | 
				
			||||||
          ['ic'] = '@class.inner',
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
      },
 | 
					 | 
				
			||||||
      move = {
 | 
					 | 
				
			||||||
        enable = true,
 | 
					 | 
				
			||||||
        set_jumps = true, -- whether to set jumps in the jumplist
 | 
					 | 
				
			||||||
        goto_next_start = {
 | 
					 | 
				
			||||||
          [']m'] = '@function.outer',
 | 
					 | 
				
			||||||
          [']]'] = '@class.outer',
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        goto_next_end = {
 | 
					 | 
				
			||||||
          [']M'] = '@function.outer',
 | 
					 | 
				
			||||||
          [']['] = '@class.outer',
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        goto_previous_start = {
 | 
					 | 
				
			||||||
          ['[m'] = '@function.outer',
 | 
					 | 
				
			||||||
          ['[['] = '@class.outer',
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        goto_previous_end = {
 | 
					 | 
				
			||||||
          ['[M'] = '@function.outer',
 | 
					 | 
				
			||||||
          ['[]'] = '@class.outer',
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
      },
 | 
					 | 
				
			||||||
      swap = {
 | 
					 | 
				
			||||||
        enable = true,
 | 
					 | 
				
			||||||
        swap_next = {
 | 
					 | 
				
			||||||
          ['<leader>a'] = '@parameter.inner',
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        swap_previous = {
 | 
					 | 
				
			||||||
          ['<leader>A'] = '@parameter.inner',
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
      },
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
end, 0)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- [[ Configure LSP ]]
 | 
					 | 
				
			||||||
--  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') Use keys to lazy load plugin(telescope-ui)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  nmap('gd', require('telescope.builtin').lsp_definitions, '[G]oto [D]efinition')
 | 
					 | 
				
			||||||
  nmap('gr', require('telescope.builtin').lsp_references, '[G]oto [R]eferences')
 | 
					 | 
				
			||||||
  nmap('gI', require('telescope.builtin').lsp_implementations, '[G]oto [I]mplementation')
 | 
					 | 
				
			||||||
  nmap('<leader>D', require('telescope.builtin').lsp_type_definitions, '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
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- document existing key chains
 | 
					 | 
				
			||||||
require('which-key').register {
 | 
					 | 
				
			||||||
  ['<leader>c'] = { name = '[C]ode', _ = 'which_key_ignore' },
 | 
					 | 
				
			||||||
  ['<leader>d'] = { name = '[D]ocument', _ = 'which_key_ignore' },
 | 
					 | 
				
			||||||
  ['<leader>g'] = { name = '[G]it', _ = 'which_key_ignore' },
 | 
					 | 
				
			||||||
  ['<leader>h'] = { name = 'Git [H]unk', _ = 'which_key_ignore' },
 | 
					 | 
				
			||||||
  ['<leader>r'] = { name = '[R]ename', _ = 'which_key_ignore' },
 | 
					 | 
				
			||||||
  ['<leader>s'] = { name = '[S]earch', _ = 'which_key_ignore' },
 | 
					 | 
				
			||||||
  ['<leader>t'] = { name = '[T]oggle', _ = 'which_key_ignore' },
 | 
					 | 
				
			||||||
  ['<leader>w'] = { name = '[W]orkspace', _ = 'which_key_ignore' },
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
-- register which-key VISUAL mode
 | 
					 | 
				
			||||||
-- required for visual <leader>hs (hunk stage) to work
 | 
					 | 
				
			||||||
require('which-key').register({
 | 
					 | 
				
			||||||
  ['<leader>'] = { name = 'VISUAL <leader>' },
 | 
					 | 
				
			||||||
  ['<leader>h'] = { 'Git [H]unk' },
 | 
					 | 
				
			||||||
}, { mode = 'v' })
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- mason-lspconfig requires that these setup functions are called in this order
 | 
					 | 
				
			||||||
-- before setting up the servers.
 | 
					 | 
				
			||||||
require('mason').setup()
 | 
					 | 
				
			||||||
require('mason-lspconfig').setup()
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- 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.
 | 
					 | 
				
			||||||
--
 | 
					 | 
				
			||||||
--  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 = {},
 | 
					 | 
				
			||||||
  -- pyright = {},
 | 
					 | 
				
			||||||
  rust_analyzer = {},
 | 
					 | 
				
			||||||
  tsserver = {},
 | 
					 | 
				
			||||||
  html = { filetypes = { 'html', 'twig', 'hbs' } },
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  lua_ls = {
 | 
					 | 
				
			||||||
    Lua = {
 | 
					 | 
				
			||||||
      workspace = { checkThirdParty = false },
 | 
					 | 
				
			||||||
      telemetry = { enable = false },
 | 
					 | 
				
			||||||
      -- NOTE: toggle below to ignore Lua_LS's noisy `missing-fields` warnings
 | 
					 | 
				
			||||||
      -- diagnostics = { disable = { 'missing-fields' } },
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
  },
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- 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)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- 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],
 | 
					 | 
				
			||||||
      filetypes = (servers[server_name] or {}).filetypes,
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
  end,
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- [[ Configure nvim-cmp ]]
 | 
					 | 
				
			||||||
-- See `:help cmp`
 | 
					 | 
				
			||||||
local cmp = require 'cmp'
 | 
					 | 
				
			||||||
local luasnip = require 'luasnip'
 | 
					 | 
				
			||||||
require('luasnip.loaders.from_vscode').lazy_load()
 | 
					 | 
				
			||||||
luasnip.config.setup {}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
cmp.setup {
 | 
					 | 
				
			||||||
  snippet = {
 | 
					 | 
				
			||||||
    expand = function(args)
 | 
					 | 
				
			||||||
      luasnip.lsp_expand(args.body)
 | 
					 | 
				
			||||||
    end,
 | 
					 | 
				
			||||||
  },
 | 
					 | 
				
			||||||
  completion = {
 | 
					 | 
				
			||||||
    completeopt = 'menu,menuone,noinsert',
 | 
					 | 
				
			||||||
  },
 | 
					 | 
				
			||||||
  mapping = cmp.mapping.preset.insert {
 | 
					 | 
				
			||||||
    ['<C-n>'] = cmp.mapping.select_next_item(),
 | 
					 | 
				
			||||||
    ['<C-p>'] = cmp.mapping.select_prev_item(),
 | 
					 | 
				
			||||||
    ['<C-b>'] = 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_locally_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.locally_jumpable(-1) then
 | 
					 | 
				
			||||||
        luasnip.jump(-1)
 | 
					 | 
				
			||||||
      else
 | 
					 | 
				
			||||||
        fallback()
 | 
					 | 
				
			||||||
      end
 | 
					 | 
				
			||||||
    end, { 'i', 's' }),
 | 
					 | 
				
			||||||
  },
 | 
					 | 
				
			||||||
  sources = {
 | 
					 | 
				
			||||||
    { name = 'nvim_lsp' },
 | 
					 | 
				
			||||||
    { name = 'luasnip' },
 | 
					 | 
				
			||||||
    { name = 'path' },
 | 
					 | 
				
			||||||
  },
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- The line beneath this is called `modeline`. See `:help modeline`
 | 
					-- The line beneath this is called `modeline`. See `:help modeline`
 | 
				
			||||||
-- vim: ts=2 sts=2 sw=2 et
 | 
					-- vim: ts=2 sts=2 sw=2 et
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in New Issue