Initial Configurations
This commit is contained in:
		
							parent
							
								
									01a1ebed38
								
							
						
					
					
						commit
						5c216504bb
					
				
							
								
								
									
										535
									
								
								init.lua
								
								
								
								
							
							
						
						
									
										535
									
								
								init.lua
								
								
								
								
							|  | @ -1,527 +1,20 @@ | ||||||
| --[[ | local lazypath = vim.fn.stdpath("data") .. "/lazy/lazy.nvim" | ||||||
| 
 |  | ||||||
| ===================================================================== |  | ||||||
| ==================== 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, understand |  | ||||||
|   what your configuration is doing, and modify it to suit your needs. |  | ||||||
| 
 |  | ||||||
|   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` |  | ||||||
|   - https://neovim.io/doc/user/lua-guide.html |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 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 | if not vim.loop.fs_stat(lazypath) then | ||||||
|   vim.fn.system { |   vim.fn.system({ | ||||||
|     'git', |     "git", | ||||||
|     'clone', |     "clone", | ||||||
|     '--filter=blob:none', |     "--filter=blob:none", | ||||||
|     'https://github.com/folke/lazy.nvim.git', |     "https://github.com/folke/lazy.nvim.git", | ||||||
|     '--branch=stable', -- latest stable release |     "--branch=stable", -- latest stable release | ||||||
|     lazypath, |     lazypath, | ||||||
|   } |   }) | ||||||
| end | end | ||||||
|  | 
 | ||||||
| vim.opt.rtp:prepend(lazypath) | vim.opt.rtp:prepend(lazypath) | ||||||
| 
 | 
 | ||||||
| -- NOTE: Here is where you install your plugins. | require("defaults.keymaps") | ||||||
| --  You can configure plugins using the `config` key. | require("defaults.settings") | ||||||
| -- | require("defaults.autocmds") | ||||||
| --  You can also configure plugins after the setup call, |  | ||||||
| --    as they will be available in your neovim runtime. |  | ||||||
| require('lazy').setup({ |  | ||||||
|   -- NOTE: First, some plugins that don't require any configuration |  | ||||||
| 
 | 
 | ||||||
|   -- Git related plugins | -- Added this line to our initial lazy-config.lua file (Remove this comment if you want to) | ||||||
|   'tpope/vim-fugitive', | require("lazy").setup('plugins') | ||||||
|   'tpope/vim-rhubarb', |  | ||||||
| 
 |  | ||||||
|   -- Detect tabstop and shiftwidth automatically |  | ||||||
|   'tpope/vim-sleuth', |  | ||||||
| 
 |  | ||||||
|   -- NOTE: This is where your plugins related to LSP can be installed. |  | ||||||
|   --  The configuration is done below. Search for lspconfig to find it below. |  | ||||||
|   { |  | ||||||
|     -- 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 |  | ||||||
|       -- NOTE: `opts = {}` is the same as calling `require('fidget').setup({})` |  | ||||||
|       { 'j-hui/fidget.nvim', tag = 'legacy', opts = {} }, |  | ||||||
| 
 |  | ||||||
|       -- Additional lua configuration, makes nvim stuff amazing! |  | ||||||
|       'folke/neodev.nvim', |  | ||||||
|     }, |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   { |  | ||||||
|     -- Autocompletion |  | ||||||
|     'hrsh7th/nvim-cmp', |  | ||||||
|     dependencies = { |  | ||||||
|       -- Snippet Engine & its associated nvim-cmp source |  | ||||||
|       'L3MON4D3/LuaSnip', |  | ||||||
|       'saadparwaiz1/cmp_luasnip', |  | ||||||
| 
 |  | ||||||
|       -- Adds LSP completion capabilities |  | ||||||
|       'hrsh7th/cmp-nvim-lsp', |  | ||||||
| 
 |  | ||||||
|       -- Adds a number of user-friendly snippets |  | ||||||
|       'rafamadriz/friendly-snippets', |  | ||||||
|     }, |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   -- Useful plugin to show you pending keybinds. |  | ||||||
|   { 'folke/which-key.nvim', opts = {} }, |  | ||||||
|   { |  | ||||||
|     -- Adds git related signs to the gutter, as well as utilities for managing changes |  | ||||||
|     'lewis6991/gitsigns.nvim', |  | ||||||
|     opts = { |  | ||||||
|       -- See `:help gitsigns.txt` |  | ||||||
|       signs = { |  | ||||||
|         add = { text = '+' }, |  | ||||||
|         change = { text = '~' }, |  | ||||||
|         delete = { text = '_' }, |  | ||||||
|         topdelete = { text = '‾' }, |  | ||||||
|         changedelete = { text = '~' }, |  | ||||||
|       }, |  | ||||||
|       on_attach = function(bufnr) |  | ||||||
|         vim.keymap.set('n', '<leader>gp', require('gitsigns').prev_hunk, { buffer = bufnr, desc = '[G]o to [P]revious Hunk' }) |  | ||||||
|         vim.keymap.set('n', '<leader>gn', require('gitsigns').next_hunk, { buffer = bufnr, desc = '[G]o to [N]ext Hunk' }) |  | ||||||
|         vim.keymap.set('n', '<leader>ph', require('gitsigns').preview_hunk, { buffer = bufnr, desc = '[P]review [H]unk' }) |  | ||||||
|       end, |  | ||||||
|     }, |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   { |  | ||||||
|     -- Theme inspired by Atom |  | ||||||
|     'navarasu/onedark.nvim', |  | ||||||
|     priority = 1000, |  | ||||||
|     config = function() |  | ||||||
|       vim.cmd.colorscheme 'onedark' |  | ||||||
|     end, |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   { |  | ||||||
|     -- Set lualine as statusline |  | ||||||
|     'nvim-lualine/lualine.nvim', |  | ||||||
|     -- See `:help lualine.txt` |  | ||||||
|     opts = { |  | ||||||
|       options = { |  | ||||||
|         icons_enabled = false, |  | ||||||
|         theme = 'onedark', |  | ||||||
|         component_separators = '|', |  | ||||||
|         section_separators = '', |  | ||||||
|       }, |  | ||||||
|     }, |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   { |  | ||||||
|     -- Add indentation guides even on blank lines |  | ||||||
|     'lukas-reineke/indent-blankline.nvim', |  | ||||||
|     -- Enable `lukas-reineke/indent-blankline.nvim` |  | ||||||
|     -- See `:help indent_blankline.txt` |  | ||||||
|     opts = { |  | ||||||
|       char = '┊', |  | ||||||
|       show_trailing_blankline_indent = false, |  | ||||||
|     }, |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   -- "gc" to comment visual regions/lines |  | ||||||
|   { 'numToStr/Comment.nvim', opts = {} }, |  | ||||||
| 
 |  | ||||||
|   -- Fuzzy Finder (files, lsp, etc) |  | ||||||
|   { |  | ||||||
|     'nvim-telescope/telescope.nvim', |  | ||||||
|     branch = '0.1.x', |  | ||||||
|     dependencies = { |  | ||||||
|       'nvim-lua/plenary.nvim', |  | ||||||
|       -- Fuzzy Finder Algorithm which requires local dependencies to be built. |  | ||||||
|       -- Only load if `make` is available. Make sure you have the system |  | ||||||
|       -- requirements installed. |  | ||||||
|       { |  | ||||||
|         'nvim-telescope/telescope-fzf-native.nvim', |  | ||||||
|         -- NOTE: If you are having trouble with this installation, |  | ||||||
|         --       refer to the README for telescope-fzf-native for more instructions. |  | ||||||
|         build = 'make', |  | ||||||
|         cond = function() |  | ||||||
|           return vim.fn.executable 'make' == 1 |  | ||||||
|         end, |  | ||||||
|       }, |  | ||||||
|     }, |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   { |  | ||||||
|     -- Highlight, edit, and navigate code |  | ||||||
|     'nvim-treesitter/nvim-treesitter', |  | ||||||
|     dependencies = { |  | ||||||
|       'nvim-treesitter/nvim-treesitter-textobjects', |  | ||||||
|     }, |  | ||||||
|     build = ':TSUpdate', |  | ||||||
|   }, |  | ||||||
| 
 |  | ||||||
|   -- NOTE: Next Step on Your Neovim Journey: Add/Configure additional "plugins" for kickstart |  | ||||||
|   --       These are some example plugins that I've included in the kickstart repository. |  | ||||||
|   --       Uncomment any of the lines below to enable them. |  | ||||||
|   -- require 'kickstart.plugins.autoformat', |  | ||||||
|   -- require 'kickstart.plugins.debug', |  | ||||||
| 
 |  | ||||||
|   -- NOTE: The import below can automatically add your own plugins, configuration, etc from `lua/custom/plugins/*.lua` |  | ||||||
|   --    You can use this folder to prevent any conflicts with this init.lua if you're interested in keeping |  | ||||||
|   --    up-to-date with whatever is in the kickstart repo. |  | ||||||
|   --    Uncomment the following line and add your plugins to `lua/custom/plugins/*.lua` to get going. |  | ||||||
|   -- |  | ||||||
|   --    For additional information see: https://github.com/folke/lazy.nvim#-structuring-your-plugins |  | ||||||
|   -- { import = 'custom.plugins' }, |  | ||||||
| }, {}) |  | ||||||
| 
 |  | ||||||
| -- [[ Setting options ]] |  | ||||||
| -- See `:help vim.o` |  | ||||||
| -- NOTE: You can change these options as you wish! |  | ||||||
| 
 |  | ||||||
| -- 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.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 |  | ||||||
| 
 |  | ||||||
| -- [[ Basic Keymaps ]] |  | ||||||
| 
 |  | ||||||
| -- Keymaps for better default experience |  | ||||||
| -- See `:help vim.keymap.set()` |  | ||||||
| vim.keymap.set({ 'n', 'v' }, '<Space>', '<Nop>', { silent = true }) |  | ||||||
| 
 |  | ||||||
| -- Remap for dealing with word wrap |  | ||||||
| vim.keymap.set('n', 'k', "v:count == 0 ? 'gk' : 'k'", { expr = true, silent = true }) |  | ||||||
| vim.keymap.set('n', 'j', "v:count == 0 ? 'gj' : 'j'", { expr = true, silent = true }) |  | ||||||
| 
 |  | ||||||
| -- [[ 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') |  | ||||||
| 
 |  | ||||||
| -- 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' }) |  | ||||||
| 
 |  | ||||||
| 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>sd', require('telescope.builtin').diagnostics, { desc = '[S]earch [D]iagnostics' }) |  | ||||||
| 
 |  | ||||||
| -- [[ Configure Treesitter ]] |  | ||||||
| -- See `:help nvim-treesitter` |  | ||||||
| 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', 'typescript', 'vimdoc', 'vim' }, |  | ||||||
| 
 |  | ||||||
|   -- 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', |  | ||||||
|       }, |  | ||||||
|     }, |  | ||||||
|   }, |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| -- Diagnostic keymaps |  | ||||||
| vim.keymap.set('n', '[d', vim.diagnostic.goto_prev, { desc = 'Go to previous diagnostic message' }) |  | ||||||
| vim.keymap.set('n', ']d', vim.diagnostic.goto_next, { desc = 'Go to next diagnostic message' }) |  | ||||||
| vim.keymap.set('n', '<leader>e', vim.diagnostic.open_float, { desc = 'Open floating diagnostic message' }) |  | ||||||
| vim.keymap.set('n', '<leader>q', vim.diagnostic.setloclist, { desc = 'Open diagnostics list' }) |  | ||||||
| 
 |  | ||||||
| -- [[ 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') |  | ||||||
| 
 |  | ||||||
|   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. |  | ||||||
| -- |  | ||||||
| --  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 }, |  | ||||||
|     }, |  | ||||||
|   }, |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| -- 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, |  | ||||||
|   }, |  | ||||||
|   mapping = cmp.mapping.preset.insert { |  | ||||||
|     ['<C-n>'] = cmp.mapping.select_next_item(), |  | ||||||
|     ['<C-p>'] = cmp.mapping.select_prev_item(), |  | ||||||
|     ['<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_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' }, |  | ||||||
|   }, |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| -- The line beneath this is called `modeline`. See `:help modeline` |  | ||||||
| -- vim: ts=2 sts=2 sw=2 et |  | ||||||
|  |  | ||||||
|  | @ -1,5 +0,0 @@ | ||||||
| -- You can add your own plugins here or in other files in this directory! |  | ||||||
| --  I promise not to create any merge conflicts in this directory :) |  | ||||||
| -- |  | ||||||
| -- See the kickstart.nvim README for more information |  | ||||||
| return {} |  | ||||||
|  | @ -0,0 +1,43 @@ | ||||||
|  | local group = vim.api.nvim_create_augroup('user_cmds', { clear = true }) | ||||||
|  | 
 | ||||||
|  | vim.api.nvim_create_user_command('ReloadConfig', 'source $MYVIMRC | PackerCompile', {}) | ||||||
|  | 
 | ||||||
|  | vim.api.nvim_create_autocmd('FileType', { | ||||||
|  |   pattern = { 'qf', 'help', 'man', 'lspinfo', 'spectre_panel' }, | ||||||
|  |   group = group, | ||||||
|  |   command = 'nnoremap <buffer> q <cmd>quit<cr>', | ||||||
|  | }) | ||||||
|  | 
 | ||||||
|  | vim.api.nvim_create_autocmd({ 'FileType' }, { | ||||||
|  |   pattern = { 'gitcommit' }, | ||||||
|  |   callback = function() | ||||||
|  |     vim.opt_local.wrap = true | ||||||
|  |     vim.opt_local.spell = true | ||||||
|  |   end, | ||||||
|  | }) | ||||||
|  | 
 | ||||||
|  | vim.cmd "autocmd BufEnter * ++nested if winnr('$') == 1 && bufname() == 'NvimTree_' . tabpagenr() | quit | endif" | ||||||
|  | 
 | ||||||
|  | vim.api.nvim_create_autocmd({ 'VimResized' }, { | ||||||
|  |   callback = function() | ||||||
|  |     vim.cmd 'tabdo wincmd =' | ||||||
|  |   end, | ||||||
|  | }) | ||||||
|  | 
 | ||||||
|  | vim.api.nvim_create_autocmd({ 'CmdWinEnter' }, { | ||||||
|  |   callback = function() | ||||||
|  |     vim.cmd 'quit' | ||||||
|  |   end, | ||||||
|  | }) | ||||||
|  | 
 | ||||||
|  | vim.api.nvim_create_autocmd({ 'TextYankPost' }, { | ||||||
|  |   callback = function() | ||||||
|  |     vim.highlight.on_yank { higroup = 'Visual', timeout = 200 } | ||||||
|  |   end, | ||||||
|  | }) | ||||||
|  | 
 | ||||||
|  | vim.api.nvim_create_autocmd({ 'VimEnter' }, { | ||||||
|  |   callback = function() | ||||||
|  |     vim.cmd 'hi link illuminatedWord LspReferenceText' | ||||||
|  |   end, | ||||||
|  | }) | ||||||
|  | @ -0,0 +1,92 @@ | ||||||
|  | -- Shorten function name | ||||||
|  | local keymap = vim.keymap.set | ||||||
|  | 
 | ||||||
|  | -- Silent keymap option | ||||||
|  | local opts = { noremap = true, silent = true } | ||||||
|  | 
 | ||||||
|  | --Remap space as leader key | ||||||
|  | keymap('', '<Space>', '<Nop>', opts) | ||||||
|  | 
 | ||||||
|  | vim.g.mapleader = ' ' | ||||||
|  | vim.g.maplocalleader = ' ' | ||||||
|  | 
 | ||||||
|  | -- Modes | ||||||
|  | --   normal_mode = "n", | ||||||
|  | --   insert_mode = "i", | ||||||
|  | --   visual_mode = "v", | ||||||
|  | --   visual_block_mode = "x", | ||||||
|  | --   term_mode = "t", | ||||||
|  | --   command_mode = "c", | ||||||
|  | 
 | ||||||
|  | -- Normal -- | ||||||
|  | -- Better window navigation | ||||||
|  | keymap('n', '<C-h>', '<C-w>h', opts) | ||||||
|  | keymap('n', '<C-j>', '<C-w>j', opts) | ||||||
|  | keymap('n', '<C-k>', '<C-w>k', opts) | ||||||
|  | keymap('n', '<C-l>', '<C-w>l', opts) | ||||||
|  | 
 | ||||||
|  | -- Resize with arrows | ||||||
|  | keymap('n', '<C-Up>', ':resize -2<CR>', opts) | ||||||
|  | keymap('n', '<C-Down>', ':resize +2<CR>', opts) | ||||||
|  | keymap('n', '<C-Left>', ':vertical resize -2<CR>', opts) | ||||||
|  | keymap('n', '<C-Right>', ':vertical resize +2<CR>', opts) | ||||||
|  | 
 | ||||||
|  | -- Navigate buffers | ||||||
|  | keymap('n', '<S-l>', ':bnext<CR>', opts) | ||||||
|  | keymap('n', '<S-h>', ':bprevious<CR>', opts) | ||||||
|  | 
 | ||||||
|  | -- Clear highlights | ||||||
|  | keymap('n', '<leader>nh', '<cmd>nohlsearch<CR>', opts) | ||||||
|  | 
 | ||||||
|  | -- delete single character without copying into register | ||||||
|  | keymap('n', 'x', '"_x', opts) | ||||||
|  | 
 | ||||||
|  | -- Close buffers | ||||||
|  | keymap('n', '<leader>bd', '<cmd>:bd<CR>', opts) | ||||||
|  | keymap('n', '<leader>bD', '<cmd>Bdelete!<CR>', opts) | ||||||
|  | 
 | ||||||
|  | -- Write file | ||||||
|  | keymap('n', '<leader>fs', '<cmd>:write<CR>', opts) | ||||||
|  | keymap('n', '<leader>fw', '<cmd>:write<CR>', opts) | ||||||
|  | keymap('n', '<leader>fS', '<cmd>:wa<CR>', opts) | ||||||
|  | keymap('n', '<leader>fW', '<cmd>:wa<CR>', opts) | ||||||
|  | 
 | ||||||
|  | -- Safe quit | ||||||
|  | keymap('n', '<Leader>qq', ':quitall<CR>', opts) | ||||||
|  | 
 | ||||||
|  | -- Force quit | ||||||
|  | keymap('n', '<Leader>Q', ':quitall!<CR>', opts) | ||||||
|  | 
 | ||||||
|  | -- Better paste | ||||||
|  | keymap('v', 'p', '"_dP', opts) | ||||||
|  | 
 | ||||||
|  | -- Insert -- | ||||||
|  | -- Press jk fast to enter | ||||||
|  | keymap('i', 'jk', '<ESC>', opts) | ||||||
|  | keymap('v', 'jk', '<ESC>', opts) | ||||||
|  | 
 | ||||||
|  | -- Visual -- | ||||||
|  | -- Stay in indent mode | ||||||
|  | keymap('v', '<', '<gv', opts) | ||||||
|  | keymap('v', '>', '>gv', opts) | ||||||
|  | 
 | ||||||
|  | -- Search will center on the line it's found in | ||||||
|  | keymap('n', 'n', 'nzzzv', opts) | ||||||
|  | keymap('n', 'N', 'Nzzzv', opts) | ||||||
|  | keymap('n', '#', '#zz', opts) | ||||||
|  | keymap('n', '*', '*zz', opts) | ||||||
|  | 
 | ||||||
|  | -- increment/decrement numbers | ||||||
|  | keymap('n', '<leader>+', '<C-a>', opts) -- increment | ||||||
|  | keymap('n', '<leader>-', '<C-x>', opts) -- decrement | ||||||
|  | 
 | ||||||
|  | -- window management | ||||||
|  | keymap('n', '<leader>wv', '<C-w>v', opts) -- split window vertically | ||||||
|  | keymap('n', '<leader>wh', '<C-w>s', opts) -- split window horizontally | ||||||
|  | keymap('n', '<leader>w-', '<C-w>s', opts) -- split window horizontally | ||||||
|  | keymap('n', '<leader>wd', ':close<CR>', opts) -- close current split window | ||||||
|  | 
 | ||||||
|  | keymap('n', '<leader>to', ':tabnew<CR>', opts) -- open new tab | ||||||
|  | keymap('n', '<leader>tx', ':tabclose<CR>', opts) -- close current tab | ||||||
|  | keymap('n', '<leader>tn', ':tabn<CR>', opts) --  go to next tab | ||||||
|  | keymap('n', '<leader>tp', ':tabp<CR>', opts) --  go to previous tab | ||||||
|  | @ -0,0 +1,87 @@ | ||||||
|  | -- vim.opt.clipboard = "unnamedplus"               -- allows neovim to access the system clipboard | ||||||
|  | vim.opt.clipboard:append 'unnamedplus' -- use system clipboard as default register | ||||||
|  | vim.opt.cmdheight = 1 -- more space in the neovim command line for displaying messages | ||||||
|  | vim.opt.completeopt = 'menu,menuone,noselect' -- cmp needs this | ||||||
|  | vim.opt.conceallevel = 0 -- so that `` is visible in markdown files | ||||||
|  | vim.opt.fileencoding = 'utf-8' -- the encoding written to a file | ||||||
|  | vim.opt.hlsearch = false -- highlight all matches on previous search pattern | ||||||
|  | vim.opt.ignorecase = true -- ignore case in search patterns | ||||||
|  | vim.opt.mouse = 'a' -- allow the mouse to be used in neovim | ||||||
|  | vim.opt.pumheight = 10 -- pop up menu height | ||||||
|  | vim.opt.showmode = false -- we don't need to see things like -- INSERT -- anymore | ||||||
|  | vim.opt.showtabline = 0 -- always show tabs | ||||||
|  | vim.opt.smartcase = true -- smart case | ||||||
|  | vim.opt.smartindent = true -- make indenting smarter again | ||||||
|  | vim.opt.splitbelow = true -- force all horizontal splits to go below current window | ||||||
|  | vim.opt.splitright = true -- force all vertical splits to go to the right of current window | ||||||
|  | vim.opt.swapfile = false -- creates a swapfile | ||||||
|  | vim.opt.termguicolors = true -- set term gui colors (most terminals support this) | ||||||
|  | vim.opt.background = 'dark' -- | ||||||
|  | vim.opt.timeoutlen = 1000 -- time to wait for a mapped sequence to complete (in milliseconds) | ||||||
|  | vim.opt.undofile = true -- enable persistent undo | ||||||
|  | vim.opt.updatetime = 300 -- faster completion (4000ms default) | ||||||
|  | vim.opt.writebackup = false -- if a file is being edited by another program (or was written to file while editing with another program), it is not allowed to be edited | ||||||
|  | vim.opt.expandtab = true -- convert tabs to spaces | ||||||
|  | vim.opt.shiftwidth = 2 -- the number of spaces inserted for each indentation | ||||||
|  | vim.opt.shiftround = true -- | ||||||
|  | vim.opt.tabstop = 2 -- insert 2 spaces for a tab | ||||||
|  | vim.opt.cursorline = true -- highlight the current line | ||||||
|  | vim.opt.number = true -- set numbered lines | ||||||
|  | vim.opt.relativenumber = true -- Relative numbers numbers | ||||||
|  | vim.opt.laststatus = 3 -- only the last window will always have a status line | ||||||
|  | vim.opt.showcmd = false -- hide (partial) command in the last line of the screen (for performance) | ||||||
|  | vim.opt.ruler = false -- hide the line and column number of the cursor position | ||||||
|  | vim.opt.numberwidth = 4 -- minimal number of columns to use for the line number {default 4} | ||||||
|  | vim.opt.signcolumn = 'yes' -- always show the sign column, otherwise it would shift the text each time | ||||||
|  | vim.opt.wrap = false -- display lines as one long line | ||||||
|  | vim.opt.scrolloff = 8 -- minimal number of screen lines to keep above and below the cursor | ||||||
|  | vim.opt.sidescrolloff = 8 -- minimal number of screen columns to keep to the left and right of the cursor if wrap is `false` | ||||||
|  | vim.opt.guifont = 'monospace:h17' -- the font used in graphical neovim applications | ||||||
|  | vim.opt.fillchars.eob = ' ' -- show empty lines at the end of a buffer as ` ` {default `~`} | ||||||
|  | vim.opt.shortmess:append 'c' -- hide all the completion messages, e.g. "-- XXX completion (YYY)", "match 1 of 2", "The only match", "Pattern not found" | ||||||
|  | vim.opt.whichwrap:append '<,>,[,],h,l' -- keys allowed to move to the previous/next line when the beginning/end of line is reached | ||||||
|  | vim.opt.iskeyword:append '-' -- treats words with `-` as single words | ||||||
|  | vim.opt.formatoptions:remove { 'c', 'r', 'o' } -- This is a sequence of letters which describes how automatic formatting is to be done | ||||||
|  | vim.opt.linebreak = true | ||||||
|  | vim.opt.backspace = 'indent,eol,start' -- allow backspace on indent, end of line or insert mode start position | ||||||
|  | vim.opt.backup = false -- creates a backup file | ||||||
|  | 
 | ||||||
|  | local disabled_built_ins = { | ||||||
|  |   '2html_plugin', | ||||||
|  |   'getscript', | ||||||
|  |   'getscriptPlugin', | ||||||
|  |   'gzip', | ||||||
|  |   'logipat', | ||||||
|  |   'loaded_netrw', | ||||||
|  |   'loaded_netrwPlugin', | ||||||
|  |   'loaded_remote_plugins', | ||||||
|  |   'loaded_tutor_mode_plugin', | ||||||
|  |   'matchit', | ||||||
|  |   'matchparen', | ||||||
|  |   'netrw', | ||||||
|  |   'netrwFileHandlers', | ||||||
|  |   'netrwPlugin', | ||||||
|  |   'netrwSettings', | ||||||
|  |   'rrhelper', | ||||||
|  |   'spellfile_plugin', | ||||||
|  |   'tar', | ||||||
|  |   'tarPlugin', | ||||||
|  |   'vimball', | ||||||
|  |   'vimballPlugin', | ||||||
|  |   'zip', | ||||||
|  |   'zipPlugin', | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | for _, plugin in pairs(disabled_built_ins) do | ||||||
|  |   vim.g['loaded_' .. plugin] = 1 | ||||||
|  | end | ||||||
|  | 
 | ||||||
|  | -- disable netrw at the very start of your init.lua (strongly advised) | ||||||
|  | vim.g.loaded_perl_provider = 0 | ||||||
|  | vim.g.loaded_ruby_provider = 0 | ||||||
|  | 
 | ||||||
|  | if vim.fn.executable 'rg' then | ||||||
|  |   -- if ripgrep installed, use that as a grepper | ||||||
|  |   vim.opt.grepprg = 'rg --vimgrep --no-heading --smart-case' | ||||||
|  |   vim.opt.grepformat = '%f:%l:%c:%m,%f:%l:%m' | ||||||
|  | end | ||||||
|  | @ -1,74 +0,0 @@ | ||||||
| -- autoformat.lua |  | ||||||
| -- |  | ||||||
| -- Use your language server to automatically format your code on save. |  | ||||||
| -- Adds additional commands as well to manage the behavior |  | ||||||
| 
 |  | ||||||
| return { |  | ||||||
|   'neovim/nvim-lspconfig', |  | ||||||
|   config = function() |  | ||||||
|     -- Switch for controlling whether you want autoformatting. |  | ||||||
|     --  Use :KickstartFormatToggle to toggle autoformatting on or off |  | ||||||
|     local format_is_enabled = true |  | ||||||
|     vim.api.nvim_create_user_command('KickstartFormatToggle', function() |  | ||||||
|       format_is_enabled = not format_is_enabled |  | ||||||
|       print('Setting autoformatting to: ' .. tostring(format_is_enabled)) |  | ||||||
|     end, {}) |  | ||||||
| 
 |  | ||||||
|     -- Create an augroup that is used for managing our formatting autocmds. |  | ||||||
|     --      We need one augroup per client to make sure that multiple clients |  | ||||||
|     --      can attach to the same buffer without interfering with each other. |  | ||||||
|     local _augroups = {} |  | ||||||
|     local get_augroup = function(client) |  | ||||||
|       if not _augroups[client.id] then |  | ||||||
|         local group_name = 'kickstart-lsp-format-' .. client.name |  | ||||||
|         local id = vim.api.nvim_create_augroup(group_name, { clear = true }) |  | ||||||
|         _augroups[client.id] = id |  | ||||||
|       end |  | ||||||
| 
 |  | ||||||
|       return _augroups[client.id] |  | ||||||
|     end |  | ||||||
| 
 |  | ||||||
|     -- Whenever an LSP attaches to a buffer, we will run this function. |  | ||||||
|     -- |  | ||||||
|     -- See `:help LspAttach` for more information about this autocmd event. |  | ||||||
|     vim.api.nvim_create_autocmd('LspAttach', { |  | ||||||
|       group = vim.api.nvim_create_augroup('kickstart-lsp-attach-format', { clear = true }), |  | ||||||
|       -- This is where we attach the autoformatting for reasonable clients |  | ||||||
|       callback = function(args) |  | ||||||
|         local client_id = args.data.client_id |  | ||||||
|         local client = vim.lsp.get_client_by_id(client_id) |  | ||||||
|         local bufnr = args.buf |  | ||||||
| 
 |  | ||||||
|         -- Only attach to clients that support document formatting |  | ||||||
|         if not client.server_capabilities.documentFormattingProvider then |  | ||||||
|           return |  | ||||||
|         end |  | ||||||
| 
 |  | ||||||
|         -- Tsserver usually works poorly. Sorry you work with bad languages |  | ||||||
|         -- You can remove this line if you know what you're doing :) |  | ||||||
|         if client.name == 'tsserver' then |  | ||||||
|           return |  | ||||||
|         end |  | ||||||
| 
 |  | ||||||
|         -- Create an autocmd that will run *before* we save the buffer. |  | ||||||
|         --  Run the formatting command for the LSP that has just attached. |  | ||||||
|         vim.api.nvim_create_autocmd('BufWritePre', { |  | ||||||
|           group = get_augroup(client), |  | ||||||
|           buffer = bufnr, |  | ||||||
|           callback = function() |  | ||||||
|             if not format_is_enabled then |  | ||||||
|               return |  | ||||||
|             end |  | ||||||
| 
 |  | ||||||
|             vim.lsp.buf.format { |  | ||||||
|               async = false, |  | ||||||
|               filter = function(c) |  | ||||||
|                 return c.id == client.id |  | ||||||
|               end, |  | ||||||
|             } |  | ||||||
|           end, |  | ||||||
|         }) |  | ||||||
|       end, |  | ||||||
|     }) |  | ||||||
|   end, |  | ||||||
| } |  | ||||||
|  | @ -1,87 +0,0 @@ | ||||||
| -- debug.lua |  | ||||||
| -- |  | ||||||
| -- Shows how to use the DAP plugin to debug your code. |  | ||||||
| -- |  | ||||||
| -- Primarily focused on configuring the debugger for Go, but can |  | ||||||
| -- be extended to other languages as well. That's why it's called |  | ||||||
| -- kickstart.nvim and not kitchen-sink.nvim ;) |  | ||||||
| 
 |  | ||||||
| return { |  | ||||||
|   -- NOTE: Yes, you can install new plugins here! |  | ||||||
|   'mfussenegger/nvim-dap', |  | ||||||
|   -- NOTE: And you can specify dependencies as well |  | ||||||
|   dependencies = { |  | ||||||
|     -- Creates a beautiful debugger UI |  | ||||||
|     'rcarriga/nvim-dap-ui', |  | ||||||
| 
 |  | ||||||
|     -- Installs the debug adapters for you |  | ||||||
|     'williamboman/mason.nvim', |  | ||||||
|     'jay-babu/mason-nvim-dap.nvim', |  | ||||||
| 
 |  | ||||||
|     -- Add your own debuggers here |  | ||||||
|     'leoluz/nvim-dap-go', |  | ||||||
|   }, |  | ||||||
|   config = function() |  | ||||||
|     local dap = require 'dap' |  | ||||||
|     local dapui = require 'dapui' |  | ||||||
| 
 |  | ||||||
|     require('mason-nvim-dap').setup { |  | ||||||
|       -- Makes a best effort to setup the various debuggers with |  | ||||||
|       -- reasonable debug configurations |  | ||||||
|       automatic_setup = true, |  | ||||||
| 
 |  | ||||||
|       -- You can provide additional configuration to the handlers, |  | ||||||
|       -- see mason-nvim-dap README for more information |  | ||||||
|       handlers = {}, |  | ||||||
| 
 |  | ||||||
|       -- You'll need to check that you have the required things installed |  | ||||||
|       -- online, please don't ask me how to install them :) |  | ||||||
|       ensure_installed = { |  | ||||||
|         -- Update this to ensure that you have the debuggers for the langs you want |  | ||||||
|         'delve', |  | ||||||
|       }, |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     -- Basic debugging keymaps, feel free to change to your liking! |  | ||||||
|     vim.keymap.set('n', '<F5>', dap.continue, { desc = 'Debug: Start/Continue' }) |  | ||||||
|     vim.keymap.set('n', '<F1>', dap.step_into, { desc = 'Debug: Step Into' }) |  | ||||||
|     vim.keymap.set('n', '<F2>', dap.step_over, { desc = 'Debug: Step Over' }) |  | ||||||
|     vim.keymap.set('n', '<F3>', dap.step_out, { desc = 'Debug: Step Out' }) |  | ||||||
|     vim.keymap.set('n', '<leader>b', dap.toggle_breakpoint, { desc = 'Debug: Toggle Breakpoint' }) |  | ||||||
|     vim.keymap.set('n', '<leader>B', function() |  | ||||||
|       dap.set_breakpoint(vim.fn.input 'Breakpoint condition: ') |  | ||||||
|     end, { desc = 'Debug: Set Breakpoint' }) |  | ||||||
| 
 |  | ||||||
|     -- Dap UI setup |  | ||||||
|     -- For more information, see |:help nvim-dap-ui| |  | ||||||
|     dapui.setup { |  | ||||||
|       -- Set icons to characters that are more likely to work in every terminal. |  | ||||||
|       --    Feel free to remove or use ones that you like more! :) |  | ||||||
|       --    Don't feel like these are good choices. |  | ||||||
|       icons = { expanded = '▾', collapsed = '▸', current_frame = '*' }, |  | ||||||
|       controls = { |  | ||||||
|         icons = { |  | ||||||
|           pause = '⏸', |  | ||||||
|           play = '▶', |  | ||||||
|           step_into = '⏎', |  | ||||||
|           step_over = '⏭', |  | ||||||
|           step_out = '⏮', |  | ||||||
|           step_back = 'b', |  | ||||||
|           run_last = '▶▶', |  | ||||||
|           terminate = '⏹', |  | ||||||
|           disconnect = '⏏', |  | ||||||
|         }, |  | ||||||
|       }, |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     -- Toggle to see last session result. Without this, you can't see session output in case of unhandled exception. |  | ||||||
|     vim.keymap.set('n', '<F7>', dapui.toggle, { desc = 'Debug: See last session result.' }) |  | ||||||
| 
 |  | ||||||
|     dap.listeners.after.event_initialized['dapui_config'] = dapui.open |  | ||||||
|     dap.listeners.before.event_terminated['dapui_config'] = dapui.close |  | ||||||
|     dap.listeners.before.event_exited['dapui_config'] = dapui.close |  | ||||||
| 
 |  | ||||||
|     -- Install golang specific config |  | ||||||
|     require('dap-go').setup() |  | ||||||
|   end, |  | ||||||
| } |  | ||||||
|  | @ -0,0 +1,37 @@ | ||||||
|  | 
 | ||||||
|  | return { | ||||||
|  |   "catppuccin/nvim", | ||||||
|  |   lazy = true, | ||||||
|  |   name = "catppuccin", | ||||||
|  |   opts = { | ||||||
|  |     integrations = { | ||||||
|  |       alpha = true, | ||||||
|  |       cmp = true, | ||||||
|  |       flash = true, | ||||||
|  |       gitsigns = true, | ||||||
|  |       illuminate = true, | ||||||
|  |       indent_blankline = { enabled = true }, | ||||||
|  |       lsp_trouble = true, | ||||||
|  |       mason = true, | ||||||
|  |       mini = true, | ||||||
|  |       native_lsp = { | ||||||
|  |         enabled = true, | ||||||
|  |         underlines = { | ||||||
|  |           errors = { "undercurl" }, | ||||||
|  |           hints = { "undercurl" }, | ||||||
|  |           warnings = { "undercurl" }, | ||||||
|  |           information = { "undercurl" }, | ||||||
|  |         }, | ||||||
|  |       }, | ||||||
|  |       navic = { enabled = true, custom_bg = "lualine" }, | ||||||
|  |       neotest = true, | ||||||
|  |       noice = true, | ||||||
|  |       notify = true, | ||||||
|  |       neotree = true, | ||||||
|  |       semantic_tokens = true, | ||||||
|  |       telescope = true, | ||||||
|  |       treesitter = true, | ||||||
|  |       which_key = true, | ||||||
|  |     }, | ||||||
|  |   }, | ||||||
|  | } | ||||||
|  | @ -0,0 +1,43 @@ | ||||||
|  | local options = { | ||||||
|  |   icons_enabled = false, | ||||||
|  |   component_separators = '|', | ||||||
|  |   section_separators = '', | ||||||
|  |   disabled_filetypes = {}, | ||||||
|  |   always_divide_middle = true, | ||||||
|  |   globalstatus = false, | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | local sections = { | ||||||
|  |   lualine_a = { 'mode' }, | ||||||
|  |   lualine_b = { 'branch', 'diff', 'diagnostics' }, | ||||||
|  |   lualine_c = { '%f', '[%-m]', 'filesize' }, | ||||||
|  |   lualine_x = { 'encoding', 'fileformat', 'filetype' }, | ||||||
|  |   lualine_y = { 'progress' }, | ||||||
|  |   lualine_z = { 'location' }, | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | local inactive_sections = { | ||||||
|  |   lualine_a = {}, | ||||||
|  |   lualine_b = {}, | ||||||
|  |   lualine_c = { 'filename' }, | ||||||
|  |   lualine_x = { 'location' }, | ||||||
|  |   lualine_y = { 'test' }, | ||||||
|  |   lualine_z = {}, | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | local tabline = {} | ||||||
|  | 
 | ||||||
|  | local extensions = {} | ||||||
|  | 
 | ||||||
|  | return { | ||||||
|  |   { | ||||||
|  |     "nvim-lualine/lualine.nvim", | ||||||
|  |     event = "VeryLazy", | ||||||
|  |     opts = function(_, opts) | ||||||
|  |       table.insert(opts, { ['options'] = options }) | ||||||
|  |       table.insert(opts, { ['sections'] = sections }) | ||||||
|  |       table.insert(opts, { ['tabline'] = tabline }) | ||||||
|  |       table.insert(opts, { ['extensions'] = extensions }) | ||||||
|  |     end, | ||||||
|  |   }, | ||||||
|  | } | ||||||
|  | @ -0,0 +1,10 @@ | ||||||
|  | return { | ||||||
|  |   "TimUntersberger/neogit", | ||||||
|  |   dependencies = "nvim-lua/plenary.nvim", | ||||||
|  |   keys = { | ||||||
|  |     { "<leader>gs", "<cmd>Neogit<CR>", desc = "Open neogit" }, | ||||||
|  |   }, | ||||||
|  |   opts = { | ||||||
|  |     use_magit_keybindings = true, | ||||||
|  |   }, | ||||||
|  | } | ||||||
|  | @ -0,0 +1,24 @@ | ||||||
|  | return { | ||||||
|  |   -- Easier comments (gc / gcc) | ||||||
|  |   { | ||||||
|  |     "numToStr/Comment.nvim", | ||||||
|  |     event = "VeryLazy", | ||||||
|  |     config = function() | ||||||
|  |       require("Comment").setup() | ||||||
|  |     end, | ||||||
|  |   }, | ||||||
|  |   -- Actions that work on surrounding context | ||||||
|  |   { "tpope/vim-surround", event = "VeryLazy" }, | ||||||
|  |   { "tpope/vim-unimpaired", event = "VeryLazy" }, | ||||||
|  | 
 | ||||||
|  |   { | ||||||
|  |     "folke/todo-comments.nvim", | ||||||
|  |     dependencies = { | ||||||
|  |       "nvim-lua/plenary.nvim", | ||||||
|  |     }, | ||||||
|  |     event = "VeryLazy", | ||||||
|  |     config = function() | ||||||
|  |       require("todo-comments").setup() | ||||||
|  |     end, | ||||||
|  |   }, | ||||||
|  | } | ||||||
|  | @ -0,0 +1,36 @@ | ||||||
|  | return { | ||||||
|  |   "nvim-telescope/telescope.nvim", | ||||||
|  |   cmd = "Telescope", | ||||||
|  |   dependencies = { | ||||||
|  |     { "nvim-lua/plenary.nvim" }, | ||||||
|  |     { 'nvim-telescope/telescope-fzf-native.nvim', | ||||||
|  |       build = 'cmake -S. -Bbuild -DCMAKE_BUILD_TYPE=Release && cmake --build build --config Release && cmake --install build --prefix build', | ||||||
|  |     }, | ||||||
|  |   }, | ||||||
|  |   keys = { | ||||||
|  |     { "<leader>ff", "<cmd>Telescope find_files<CR>", desc = "Find Files" }, | ||||||
|  |     { "<leader>ft", "<cmd>Telescope live_grep<CR>", desc = "Find a string" }, | ||||||
|  |     { "<leader>fb", "<cmd>Telescope buffers<CR>", desc = "Find buffers" }, | ||||||
|  |     { "<leader>fh", "<cmd>Telescope help_tags<CR>", desc = "Help" }, | ||||||
|  |     { "<leader>fk", "<cmd>Telescope keymaps<CR>", desc = "Find keymaps" }, | ||||||
|  |   }, | ||||||
|  |   opts = { | ||||||
|  |     defaults = { | ||||||
|  |       prompt_prefix = "> ", | ||||||
|  |       selection_caret = "> ", | ||||||
|  |       path_display = { "smart" }, | ||||||
|  |       file_ignore_patterns = { ".git", "node_modules", ".idea", ".cache", "build_*" }, | ||||||
|  |     }, | ||||||
|  |     extensions = { | ||||||
|  |       fzf = { | ||||||
|  |         fuzzy = true, -- false will only do exact matching | ||||||
|  |         override_generic_sorter = true, -- override the generic sorter | ||||||
|  |         override_file_sorter = true, -- override the file sorter | ||||||
|  |         case_mode = "smart_case", -- or "ignore_case" or "respect_case" | ||||||
|  |       }, | ||||||
|  |     }, | ||||||
|  |   }, | ||||||
|  |   config = function() | ||||||
|  |     require("telescope").load_extension("fzf") | ||||||
|  |   end, | ||||||
|  | } | ||||||
|  | @ -0,0 +1,5 @@ | ||||||
|  | return { | ||||||
|  |   "folke/tokyonight.nvim", | ||||||
|  |   lazy = true, | ||||||
|  |   opts = { style = "moon" }, | ||||||
|  | } | ||||||
|  | @ -0,0 +1,82 @@ | ||||||
|  | local load_textobjects = false | ||||||
|  | return { | ||||||
|  |   { | ||||||
|  |     "nvim-treesitter/nvim-treesitter", | ||||||
|  |     version = false, -- last release is way too old and doesn't work on Windows | ||||||
|  |     build = ":TSUpdate", | ||||||
|  |     event = { "BufReadPost", "BufNewFile" }, | ||||||
|  |     dependencies = { | ||||||
|  |       { | ||||||
|  |         "nvim-treesitter/nvim-treesitter-textobjects", | ||||||
|  |         init = function() | ||||||
|  |           -- disable rtp plugin, as we only need its queries for mini.ai | ||||||
|  |           -- In case other textobject modules are enabled, we will load them | ||||||
|  |           -- once nvim-treesitter is loaded | ||||||
|  |           require("lazy.core.loader").disable_rtp_plugin("nvim-treesitter-textobjects") | ||||||
|  |           load_textobjects = true | ||||||
|  |         end, | ||||||
|  |       }, | ||||||
|  |     }, | ||||||
|  |     cmd = { "TSUpdateSync" }, | ||||||
|  |     keys = { | ||||||
|  |       { "<c-space>", desc = "Increment selection" }, | ||||||
|  |       { "<bs>", desc = "Decrement selection", mode = "x" }, | ||||||
|  |     }, | ||||||
|  |     ---@type TSConfig | ||||||
|  |     opts = { | ||||||
|  |       highlight = { enable = true }, | ||||||
|  |       indent = { enable = true }, | ||||||
|  |       ensure_installed = { | ||||||
|  |         "bash", | ||||||
|  |         "c", | ||||||
|  |         "cpp", | ||||||
|  |         "html", | ||||||
|  |         "json", | ||||||
|  |         "lua", | ||||||
|  |         "markdown", | ||||||
|  |         "python", | ||||||
|  |         "rust", | ||||||
|  |         "yaml", | ||||||
|  |       }, | ||||||
|  |       incremental_selection = { | ||||||
|  |         enable = true, | ||||||
|  |         keymaps = { | ||||||
|  |           init_selection = "<C-space>", | ||||||
|  |           node_incremental = "<C-space>", | ||||||
|  |           scope_incremental = false, | ||||||
|  |           node_decremental = "<bs>", | ||||||
|  |         }, | ||||||
|  |       }, | ||||||
|  |     }, | ||||||
|  |     ---@param opts TSConfig | ||||||
|  |     config = function(_, opts) | ||||||
|  |       if type(opts.ensure_installed) == "table" then | ||||||
|  |         ---@type table<string, boolean> | ||||||
|  |         local added = {} | ||||||
|  |         opts.ensure_installed = vim.tbl_filter(function(lang) | ||||||
|  |           if added[lang] then | ||||||
|  |             return false | ||||||
|  |           end | ||||||
|  |           added[lang] = true | ||||||
|  |           return true | ||||||
|  |         end, opts.ensure_installed) | ||||||
|  |       end | ||||||
|  |       require("nvim-treesitter.configs").setup(opts) | ||||||
|  | 
 | ||||||
|  |       if load_textobjects then | ||||||
|  |         -- PERF: no need to load the plugin, if we only need its queries for mini.ai | ||||||
|  |         if opts.textobjects then | ||||||
|  |           for _, mod in ipairs({ "move", "select", "swap", "lsp_interop" }) do | ||||||
|  |             if opts.textobjects[mod] and opts.textobjects[mod].enable then | ||||||
|  |               local Loader = require("lazy.core.loader") | ||||||
|  |               Loader.disabled_rtp_plugins["nvim-treesitter-textobjects"] = nil | ||||||
|  |               local plugin = require("lazy.core.config").plugins["nvim-treesitter-textobjects"] | ||||||
|  |               require("lazy.core.loader").source_runtime(plugin.dir, "plugin") | ||||||
|  |               break | ||||||
|  |             end | ||||||
|  |           end | ||||||
|  |         end | ||||||
|  |       end | ||||||
|  |     end, | ||||||
|  |   }, | ||||||
|  | } | ||||||
|  | @ -0,0 +1,5 @@ | ||||||
|  | return { | ||||||
|  |   "folke/neodev.nvim", | ||||||
|  |   "folke/which-key.nvim", | ||||||
|  |   { "folke/neoconf.nvim", cmd = "Neoconf" }, | ||||||
|  | } | ||||||
		Loading…
	
		Reference in New Issue