Add files
This commit is contained in:
		
							parent
							
								
									b115814916
								
							
						
					
					
						commit
						95a87d9a4d
					
				| 
						 | 
					@ -4,6 +4,7 @@ on: pull_request_target
 | 
				
			||||||
 | 
					
 | 
				
			||||||
jobs:
 | 
					jobs:
 | 
				
			||||||
  stylua-check:
 | 
					  stylua-check:
 | 
				
			||||||
 | 
					    if: github.repository == 'nvim-lua/kickstart.nvim'
 | 
				
			||||||
    name: Stylua Check
 | 
					    name: Stylua Check
 | 
				
			||||||
    runs-on: ubuntu-latest
 | 
					    runs-on: ubuntu-latest
 | 
				
			||||||
    steps:
 | 
					    steps:
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										74
									
								
								README.md
								
								
								
								
							
							
						
						
									
										74
									
								
								README.md
								
								
								
								
							| 
						 | 
					@ -1,13 +1,14 @@
 | 
				
			||||||
# kickstart.nvim
 | 
					# kickstart-modular.nvim
 | 
				
			||||||
 | 
					
 | 
				
			||||||
https://github.com/kdheepak/kickstart.nvim/assets/1813121/f3ff9a2b-c31f-44df-a4fa-8a0d7b17cf7b
 | 
					https://github.com/kdheepak/kickstart.nvim/assets/1813121/f3ff9a2b-c31f-44df-a4fa-8a0d7b17cf7b
 | 
				
			||||||
 | 
					
 | 
				
			||||||
### Introduction
 | 
					### Introduction
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					*This is a fork of [nvim-lua/kickstart.nvim](https://github.com/nvim-lua/kickstart.nvim) that moves from a single file to a multi file configuration.*
 | 
				
			||||||
 | 
					
 | 
				
			||||||
A starting point for Neovim that is:
 | 
					A starting point for Neovim that is:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
* Small
 | 
					* Small
 | 
				
			||||||
* Single-file (with examples of moving to multi-file)
 | 
					 | 
				
			||||||
* Documented
 | 
					* Documented
 | 
				
			||||||
* Modular
 | 
					* Modular
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -41,17 +42,17 @@ Clone kickstart.nvim:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
- on Linux and Mac
 | 
					- on Linux and Mac
 | 
				
			||||||
```sh
 | 
					```sh
 | 
				
			||||||
git clone https://github.com/nvim-lua/kickstart.nvim.git "${XDG_CONFIG_HOME:-$HOME/.config}"/nvim
 | 
					git clone https://github.com/dam9000/kickstart-modular.nvim.git "${XDG_CONFIG_HOME:-$HOME/.config}"/nvim
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
- on Windows (cmd)
 | 
					- on Windows (cmd)
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
git clone https://github.com/nvim-lua/kickstart.nvim.git %userprofile%\AppData\Local\nvim\ 
 | 
					git clone https://github.com/dam9000/kickstart-modular.nvim.git %userprofile%\AppData\Local\nvim\
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
- on Windows (powershell)
 | 
					- on Windows (powershell)
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
git clone https://github.com/nvim-lua/kickstart.nvim.git $env:USERPROFILE\AppData\Local\nvim\ 
 | 
					git clone https://github.com/dam9000/kickstart-modular.nvim.git $env:USERPROFILE\AppData\Local\nvim\
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -80,14 +81,14 @@ See [Effective Neovim: Instant IDE](https://youtu.be/stqUbv-5u2s), covering the
 | 
				
			||||||
[Fork](https://docs.github.com/en/get-started/quickstart/fork-a-repo) this repo (so that you have your own copy that you can modify) and then installing you can install to your machine using the methods above.
 | 
					[Fork](https://docs.github.com/en/get-started/quickstart/fork-a-repo) this repo (so that you have your own copy that you can modify) and then installing you can install to your machine using the methods above.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
> **NOTE**  
 | 
					> **NOTE**  
 | 
				
			||||||
> Your fork's url will be something like this: `https://github.com/<your_github_username>/kickstart.nvim.git`
 | 
					> Your fork's url will be something like this: `https://github.com/<your_github_username>/kickstart-modular.nvim.git`
 | 
				
			||||||
 | 
					
 | 
				
			||||||
### Configuration And Extension
 | 
					### Configuration And Extension
 | 
				
			||||||
 | 
					
 | 
				
			||||||
* Inside of your copy, feel free to modify any file you like! It's your copy!
 | 
					* Inside of your copy, feel free to modify any file you like! It's your copy!
 | 
				
			||||||
* Feel free to change any of the default options in `init.lua` to better suit your needs.
 | 
					* Feel free to change any of the default options in `init.lua` to better suit your needs.
 | 
				
			||||||
* For adding plugins, there are 3 primary options:
 | 
					* For adding plugins, there are 3 primary options:
 | 
				
			||||||
  * Add new configuration in `lua/custom/plugins/*` files, which will be auto sourced using `lazy.nvim` (uncomment the line importing the `custom/plugins` directory in the `init.lua` file to enable this)
 | 
					  * Add new configuration in `lua/custom/plugins/*` files, which will be auto sourced using `lazy.nvim` (uncomment the line importing the `custom/plugins` directory in the `lua/lazy-plugins.lua` file to enable this)
 | 
				
			||||||
  * Modify `init.lua` with additional plugins.
 | 
					  * Modify `init.lua` with additional plugins.
 | 
				
			||||||
  * Include the `lua/kickstart/plugins/*` files in your configuration.
 | 
					  * Include the `lua/kickstart/plugins/*` files in your configuration.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -171,9 +172,10 @@ Each PR, especially those which increase the line count, should have a descripti
 | 
				
			||||||
  * The main purpose of kickstart is to serve as a teaching tool and a reference
 | 
					  * The main purpose of kickstart is to serve as a teaching tool and a reference
 | 
				
			||||||
    configuration that someone can easily `git clone` as a basis for their own.
 | 
					    configuration that someone can easily `git clone` as a basis for their own.
 | 
				
			||||||
    As you progress in learning Neovim and Lua, you might consider splitting `init.lua`
 | 
					    As you progress in learning Neovim and Lua, you might consider splitting `init.lua`
 | 
				
			||||||
    into smaller parts. A fork of kickstart that does this while maintaining the exact
 | 
					    into smaller parts. *This is the fork of the original project that splits the configuration into smaller parts.*
 | 
				
			||||||
    same functionality is available here:
 | 
					    The original repo that maintains the exact
 | 
				
			||||||
    * [kickstart-modular.nvim](https://github.com/dam9000/kickstart-modular.nvim)
 | 
					    same functionality in a single `init.lua` file is available here:
 | 
				
			||||||
 | 
					    * [kickstart.nvim](https://github.com/dam9000/kickstart-modular.nvim)
 | 
				
			||||||
  * Discussions on this topic can be found here:
 | 
					  * Discussions on this topic can be found here:
 | 
				
			||||||
    * [Restructure the configuration](https://github.com/nvim-lua/kickstart.nvim/issues/218)
 | 
					    * [Restructure the configuration](https://github.com/nvim-lua/kickstart.nvim/issues/218)
 | 
				
			||||||
    * [Reorganize init.lua into a multi-file setup](https://github.com/nvim-lua/kickstart.nvim/pull/473)
 | 
					    * [Reorganize init.lua into a multi-file setup](https://github.com/nvim-lua/kickstart.nvim/pull/473)
 | 
				
			||||||
| 
						 | 
					@ -192,3 +194,55 @@ This requires:
 | 
				
			||||||
{'nvim-telescope/telescope-fzf-native.nvim', build = 'cmake -S. -Bbuild -DCMAKE_BUILD_TYPE=Release && cmake --build build --config Release && cmake --install build --prefix build' }
 | 
					{'nvim-telescope/telescope-fzf-native.nvim', build = 'cmake -S. -Bbuild -DCMAKE_BUILD_TYPE=Release && cmake --build build --config Release && cmake --install build --prefix build' }
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Hints And Tips For New Neovimmers
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Neovim is a very rich and powerful environment, but it can also feel a bit
 | 
				
			||||||
 | 
					intimidating for new users trying to find their way around, especially if
 | 
				
			||||||
 | 
					they're coming from other environments like Visual Studio Code or a traditional
 | 
				
			||||||
 | 
					IDE.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					There's no way this README can provide you with everything you need to know, but
 | 
				
			||||||
 | 
					here are a few tips so you can learn how to learn.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Use The Help, Luke!
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Neovim's help system is incredibly thorough and extensive. You should really
 | 
				
			||||||
 | 
					take a moment to get comfortable navigating through help topics, going back and
 | 
				
			||||||
 | 
					forth, navigating the menus, etc. This won't just help you read the help, it
 | 
				
			||||||
 | 
					will empower you in the rest of your Neovim journey.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					You can double click on a topic to drill down, and hit Ctrl-o (Hold down the
 | 
				
			||||||
 | 
					Control key and the 'o' key) to go back.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Read the first page you get when you run :help carefully. it will serve you
 | 
				
			||||||
 | 
					well.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					You can also get help on a particular thing by typing ":help <topic>".
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Like, let's say we want to learn more about folding, just type ":help folding".
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### To The Telescope!
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					One of the more powerful features you get by installing this project is the
 | 
				
			||||||
 | 
					brilliant Telescope plugin co-written by @tjdevries.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Take a minute to browse through ":help telescope" and get a sense for all the
 | 
				
			||||||
 | 
					amazing superpowers you've gained.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					In particular, there are two Telescope features that are incredible for helping
 | 
				
			||||||
 | 
					you understand how to do a particular thing or how to configure a particular
 | 
				
			||||||
 | 
					feature.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					If you're not sure what to look for, try ":Telescope help_tags". Let's say we
 | 
				
			||||||
 | 
					want to configure Neovim to automatically word wrap. We might type ":Telescope
 | 
				
			||||||
 | 
					help_tags" and then type w, r, a, p. Notice how the list of results changes with
 | 
				
			||||||
 | 
					each new letter you type? When you're done you've got a screen full of topics
 | 
				
			||||||
 | 
					involving word wrap.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Another common question is "What keys do I hit to make a thing happen?". To get
 | 
				
			||||||
 | 
					an answer, one way is to use ":Telescope keymaps". You'll get the same list of
 | 
				
			||||||
 | 
					results that changes to adapt with each new key you press.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					With these hints in mind you should be in good shape to get learning. Remember,
 | 
				
			||||||
 | 
					you are on a journey of discovery here, adapting your programming environment to
 | 
				
			||||||
 | 
					your needs. It will take effort, but the rewards are worth it! :)
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										619
									
								
								init.lua
								
								
								
								
							
							
						
						
									
										619
									
								
								init.lua
								
								
								
								
							| 
						 | 
					@ -45,627 +45,32 @@ vim.g.mapleader = ' '
 | 
				
			||||||
vim.g.maplocalleader = ' '
 | 
					vim.g.maplocalleader = ' '
 | 
				
			||||||
 | 
					
 | 
				
			||||||
-- [[ Install `lazy.nvim` plugin manager ]]
 | 
					-- [[ Install `lazy.nvim` plugin manager ]]
 | 
				
			||||||
--    https://github.com/folke/lazy.nvim
 | 
					require 'lazy-bootstrap'
 | 
				
			||||||
--    `:help lazy.nvim.txt` for more info
 | 
					 | 
				
			||||||
local lazypath = vim.fn.stdpath 'data' .. '/lazy/lazy.nvim'
 | 
					 | 
				
			||||||
if not vim.loop.fs_stat(lazypath) then
 | 
					 | 
				
			||||||
  vim.fn.system {
 | 
					 | 
				
			||||||
    'git',
 | 
					 | 
				
			||||||
    'clone',
 | 
					 | 
				
			||||||
    '--filter=blob:none',
 | 
					 | 
				
			||||||
    'https://github.com/folke/lazy.nvim.git',
 | 
					 | 
				
			||||||
    '--branch=stable', -- latest stable release
 | 
					 | 
				
			||||||
    lazypath,
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
end
 | 
					 | 
				
			||||||
vim.opt.rtp:prepend(lazypath)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
-- [[ Configure plugins ]]
 | 
					-- [[ Configure plugins ]]
 | 
				
			||||||
-- NOTE: Here is where you install your plugins.
 | 
					require 'lazy-plugins'
 | 
				
			||||||
--  You can configure plugins using the `config` key.
 | 
					 | 
				
			||||||
--
 | 
					 | 
				
			||||||
--  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
 | 
					 | 
				
			||||||
  'tpope/vim-fugitive',
 | 
					 | 
				
			||||||
  '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', 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',
 | 
					 | 
				
			||||||
      'hrsh7th/cmp-path',
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      -- 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)
 | 
					 | 
				
			||||||
        local gs = package.loaded.gitsigns
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        local function map(mode, l, r, opts)
 | 
					 | 
				
			||||||
          opts = opts or {}
 | 
					 | 
				
			||||||
          opts.buffer = bufnr
 | 
					 | 
				
			||||||
          vim.keymap.set(mode, l, r, opts)
 | 
					 | 
				
			||||||
        end
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        -- Navigation
 | 
					 | 
				
			||||||
        map({ 'n', 'v' }, ']c', function()
 | 
					 | 
				
			||||||
          if vim.wo.diff then
 | 
					 | 
				
			||||||
            return ']c'
 | 
					 | 
				
			||||||
          end
 | 
					 | 
				
			||||||
          vim.schedule(function()
 | 
					 | 
				
			||||||
            gs.next_hunk()
 | 
					 | 
				
			||||||
          end)
 | 
					 | 
				
			||||||
          return '<Ignore>'
 | 
					 | 
				
			||||||
        end, { expr = true, desc = 'Jump to next hunk' })
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        map({ 'n', 'v' }, '[c', function()
 | 
					 | 
				
			||||||
          if vim.wo.diff then
 | 
					 | 
				
			||||||
            return '[c'
 | 
					 | 
				
			||||||
          end
 | 
					 | 
				
			||||||
          vim.schedule(function()
 | 
					 | 
				
			||||||
            gs.prev_hunk()
 | 
					 | 
				
			||||||
          end)
 | 
					 | 
				
			||||||
          return '<Ignore>'
 | 
					 | 
				
			||||||
        end, { expr = true, desc = 'Jump to previous hunk' })
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        -- Actions
 | 
					 | 
				
			||||||
        -- visual mode
 | 
					 | 
				
			||||||
        map('v', '<leader>hs', function()
 | 
					 | 
				
			||||||
          gs.stage_hunk { vim.fn.line '.', vim.fn.line 'v' }
 | 
					 | 
				
			||||||
        end, { desc = 'stage git hunk' })
 | 
					 | 
				
			||||||
        map('v', '<leader>hr', function()
 | 
					 | 
				
			||||||
          gs.reset_hunk { vim.fn.line '.', vim.fn.line 'v' }
 | 
					 | 
				
			||||||
        end, { desc = 'reset git hunk' })
 | 
					 | 
				
			||||||
        -- normal mode
 | 
					 | 
				
			||||||
        map('n', '<leader>hs', gs.stage_hunk, { desc = 'git stage hunk' })
 | 
					 | 
				
			||||||
        map('n', '<leader>hr', gs.reset_hunk, { desc = 'git reset hunk' })
 | 
					 | 
				
			||||||
        map('n', '<leader>hS', gs.stage_buffer, { desc = 'git Stage buffer' })
 | 
					 | 
				
			||||||
        map('n', '<leader>hu', gs.undo_stage_hunk, { desc = 'undo stage hunk' })
 | 
					 | 
				
			||||||
        map('n', '<leader>hR', gs.reset_buffer, { desc = 'git Reset buffer' })
 | 
					 | 
				
			||||||
        map('n', '<leader>hp', gs.preview_hunk, { desc = 'preview git hunk' })
 | 
					 | 
				
			||||||
        map('n', '<leader>hb', function()
 | 
					 | 
				
			||||||
          gs.blame_line { full = false }
 | 
					 | 
				
			||||||
        end, { desc = 'git blame line' })
 | 
					 | 
				
			||||||
        map('n', '<leader>hd', gs.diffthis, { desc = 'git diff against index' })
 | 
					 | 
				
			||||||
        map('n', '<leader>hD', function()
 | 
					 | 
				
			||||||
          gs.diffthis '~'
 | 
					 | 
				
			||||||
        end, { desc = 'git diff against last commit' })
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        -- Toggles
 | 
					 | 
				
			||||||
        map('n', '<leader>tb', gs.toggle_current_line_blame, { desc = 'toggle git blame line' })
 | 
					 | 
				
			||||||
        map('n', '<leader>td', gs.toggle_deleted, { desc = 'toggle git show deleted' })
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        -- Text object
 | 
					 | 
				
			||||||
        map({ 'o', 'x' }, 'ih', ':<C-U>Gitsigns select_hunk<CR>', { desc = 'select git hunk' })
 | 
					 | 
				
			||||||
      end,
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
  },
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  {
 | 
					 | 
				
			||||||
    -- Theme inspired by Atom
 | 
					 | 
				
			||||||
    'navarasu/onedark.nvim',
 | 
					 | 
				
			||||||
    priority = 1000,
 | 
					 | 
				
			||||||
    lazy = false,
 | 
					 | 
				
			||||||
    config = function()
 | 
					 | 
				
			||||||
      require('onedark').setup {
 | 
					 | 
				
			||||||
        -- Set a style preset. 'dark' is default.
 | 
					 | 
				
			||||||
        style = 'dark', -- dark, darker, cool, deep, warm, warmer, light
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
      require('onedark').load()
 | 
					 | 
				
			||||||
    end,
 | 
					 | 
				
			||||||
  },
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  {
 | 
					 | 
				
			||||||
    -- Set lualine as statusline
 | 
					 | 
				
			||||||
    'nvim-lualine/lualine.nvim',
 | 
					 | 
				
			||||||
    -- See `:help lualine.txt`
 | 
					 | 
				
			||||||
    opts = {
 | 
					 | 
				
			||||||
      options = {
 | 
					 | 
				
			||||||
        icons_enabled = false,
 | 
					 | 
				
			||||||
        theme = 'auto',
 | 
					 | 
				
			||||||
        component_separators = '|',
 | 
					 | 
				
			||||||
        section_separators = '',
 | 
					 | 
				
			||||||
      },
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
  },
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  {
 | 
					 | 
				
			||||||
    -- Add indentation guides even on blank lines
 | 
					 | 
				
			||||||
    'lukas-reineke/indent-blankline.nvim',
 | 
					 | 
				
			||||||
    -- Enable `lukas-reineke/indent-blankline.nvim`
 | 
					 | 
				
			||||||
    -- See `:help ibl`
 | 
					 | 
				
			||||||
    main = 'ibl',
 | 
					 | 
				
			||||||
    opts = {},
 | 
					 | 
				
			||||||
  },
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  -- "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 ]]
 | 
					-- [[ Setting options ]]
 | 
				
			||||||
-- See `:help vim.o`
 | 
					require 'options'
 | 
				
			||||||
-- 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 ]]
 | 
					-- [[ Basic Keymaps ]]
 | 
				
			||||||
 | 
					require '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 })
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- 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' })
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
-- [[ 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 ]]
 | 
					-- [[ Configure Telescope ]]
 | 
				
			||||||
-- See `:help telescope` and `:help telescope.setup()`
 | 
					-- (fuzzy finder)
 | 
				
			||||||
require('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 ]]
 | 
					-- [[ Configure Treesitter ]]
 | 
				
			||||||
-- See `:help nvim-treesitter`
 | 
					-- (syntax parser for highlighting)
 | 
				
			||||||
-- Defer Treesitter setup after first render to improve startup time of 'nvim {filename}'
 | 
					require 'treesitter-setup'
 | 
				
			||||||
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' },
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    -- Autoinstall languages that are not installed. Defaults to false (but you can change for yourself!)
 | 
					 | 
				
			||||||
    auto_install = false,
 | 
					 | 
				
			||||||
    -- Install languages synchronously (only applied to `ensure_installed`)
 | 
					 | 
				
			||||||
    sync_install = false,
 | 
					 | 
				
			||||||
    -- List of parsers to ignore installing
 | 
					 | 
				
			||||||
    ignore_install = {},
 | 
					 | 
				
			||||||
    -- You can specify additional Treesitter modules here: -- For example: -- playground = {--enable = true,-- },
 | 
					 | 
				
			||||||
    modules = {},
 | 
					 | 
				
			||||||
    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 ]]
 | 
					-- [[ Configure LSP ]]
 | 
				
			||||||
--  This function gets run when an LSP connects to a particular buffer.
 | 
					-- (Language Server Protocol)
 | 
				
			||||||
local on_attach = function(_, bufnr)
 | 
					require 'lsp-setup'
 | 
				
			||||||
  -- 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', 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 ]]
 | 
					-- [[ Configure nvim-cmp ]]
 | 
				
			||||||
-- See `:help cmp`
 | 
					-- (completion)
 | 
				
			||||||
local cmp = require 'cmp'
 | 
					require 'cmp-setup'
 | 
				
			||||||
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
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,41 @@
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					  "Comment.nvim": { "branch": "master", "commit": "0236521ea582747b58869cb72f70ccfa967d2e89" },
 | 
				
			||||||
 | 
					  "LuaSnip": { "branch": "master", "commit": "2dbef19461198630b3d7c39f414d09fb07d1fdd2" },
 | 
				
			||||||
 | 
					  "cmp-nvim-lsp": { "branch": "main", "commit": "5af77f54de1b16c34b23cba810150689a3a90312" },
 | 
				
			||||||
 | 
					  "cmp-path": { "branch": "main", "commit": "91ff86cd9c29299a64f968ebb45846c485725f23" },
 | 
				
			||||||
 | 
					  "cmp_luasnip": { "branch": "master", "commit": "05a9ab28b53f71d1aece421ef32fee2cb857a843" },
 | 
				
			||||||
 | 
					  "fidget.nvim": { "branch": "main", "commit": "a3e1e79116ceb93d4c8c0ff432bf506b3213a24d" },
 | 
				
			||||||
 | 
					  "friendly-snippets": { "branch": "main", "commit": "b8fae73a479ae0a1c54f5c98fa687ae8a0addc53" },
 | 
				
			||||||
 | 
					  "gitsigns.nvim": { "branch": "main", "commit": "2c2463dbd82eddd7dbab881c3a62cfbfbe3c67ae" },
 | 
				
			||||||
 | 
					  "indent-blankline.nvim": { "branch": "master", "commit": "12e92044d313c54c438bd786d11684c88f6f78cd" },
 | 
				
			||||||
 | 
					  "lazy.nvim": { "branch": "main", "commit": "aedcd79811d491b60d0a6577a9c1701063c2a609" },
 | 
				
			||||||
 | 
					  "lazygit.nvim": { "branch": "main", "commit": "1e08e3f5ac1152339690140e61a4a32b3bdc7de5" },
 | 
				
			||||||
 | 
					  "lualine.nvim": { "branch": "master", "commit": "7d131a8d3ba5016229e8a1d08bf8782acea98852" },
 | 
				
			||||||
 | 
					  "magic-bang.nvim": { "branch": "master", "commit": "d52237c328c0b6e6f7fa28dac5e57e677e4ab130" },
 | 
				
			||||||
 | 
					  "mason-lspconfig.nvim": { "branch": "main", "commit": "0954d7730e749d606ddf8d7ae8846848be435d53" },
 | 
				
			||||||
 | 
					  "mason-nvim-dap.nvim": { "branch": "main", "commit": "3614a39aae98ccd34124b072939d6283853b3dd2" },
 | 
				
			||||||
 | 
					  "mason.nvim": { "branch": "main", "commit": "c43eeb5614a09dc17c03a7fb49de2e05de203924" },
 | 
				
			||||||
 | 
					  "neo-tree.nvim": { "branch": "main", "commit": "e578fe7a5832421b0d2c5b3c0a7a1e40e0f6a47a" },
 | 
				
			||||||
 | 
					  "neodev.nvim": { "branch": "main", "commit": "0ee95ecefc8ea45898a0383364f736e098c8703f" },
 | 
				
			||||||
 | 
					  "nui.nvim": { "branch": "main", "commit": "35da9ca1de0fc4dda96c2e214d93d363c145f418" },
 | 
				
			||||||
 | 
					  "nvim-autopairs": { "branch": "master", "commit": "096d0baecc34f6c5d8a6dd25851e9d5ad338209b" },
 | 
				
			||||||
 | 
					  "nvim-cmp": { "branch": "main", "commit": "04e0ca376d6abdbfc8b52180f8ea236cbfddf782" },
 | 
				
			||||||
 | 
					  "nvim-dap": { "branch": "master", "commit": "9adbfdca13afbe646d09a8d7a86d5d031fb9c5a5" },
 | 
				
			||||||
 | 
					  "nvim-dap-go": { "branch": "main", "commit": "a5cc8dcad43f0732585d4793deb02a25c4afb766" },
 | 
				
			||||||
 | 
					  "nvim-dap-ui": { "branch": "master", "commit": "d845ebd798ad1cf30aa4abd4c4eff795cdcfdd4f" },
 | 
				
			||||||
 | 
					  "nvim-lspconfig": { "branch": "master", "commit": "d12140c5687a1186b95b3f42dbc6cc769df0cf0d" },
 | 
				
			||||||
 | 
					  "nvim-markdown": { "branch": "master", "commit": "017b3644fd46f625bdeaa280a324ef75a4933b4f" },
 | 
				
			||||||
 | 
					  "nvim-surround": { "branch": "main", "commit": "703ec63aa798e5e07d309b35e42def34bebe0174" },
 | 
				
			||||||
 | 
					  "nvim-treesitter": { "branch": "master", "commit": "4fbf150a1621d52f17b099506e1a32f107079210" },
 | 
				
			||||||
 | 
					  "nvim-treesitter-textobjects": { "branch": "master", "commit": "8edd5a6d96936bdff23333d3bc177481388839e5" },
 | 
				
			||||||
 | 
					  "nvim-web-devicons": { "branch": "master", "commit": "313d9e7193354c5de7cdb1724f9e2d3f442780b0" },
 | 
				
			||||||
 | 
					  "onedark.nvim": { "branch": "master", "commit": "1230aaf2a427b2c5b73aba6e4a9a5881d3e69429" },
 | 
				
			||||||
 | 
					  "plenary.nvim": { "branch": "master", "commit": "4f71c0c4a196ceb656c824a70792f3df3ce6bb6d" },
 | 
				
			||||||
 | 
					  "ruff-lsp": { "branch": "main", "commit": "d7f8b4346b03d49f52ada7f89192e9d3ac97916b" },
 | 
				
			||||||
 | 
					  "telescope-fzf-native.nvim": { "branch": "main", "commit": "6c921ca12321edaa773e324ef64ea301a1d0da62" },
 | 
				
			||||||
 | 
					  "telescope.nvim": { "branch": "0.1.x", "commit": "d90956833d7c27e73c621a61f20b29fdb7122709" },
 | 
				
			||||||
 | 
					  "vim-fugitive": { "branch": "master", "commit": "e7bf502a6ae492f42a91d231864e25630286319b" },
 | 
				
			||||||
 | 
					  "vim-rhubarb": { "branch": "master", "commit": "ee69335de176d9325267b0fd2597a22901d927b1" },
 | 
				
			||||||
 | 
					  "vim-sleuth": { "branch": "master", "commit": "1cc4557420f215d02c4d2645a748a816c220e99b" },
 | 
				
			||||||
 | 
					  "which-key.nvim": { "branch": "main", "commit": "4433e5ec9a507e5097571ed55c02ea9658fb268a" }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,53 @@
 | 
				
			||||||
 | 
					-- [[ 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' },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					-- vim: ts=2 sts=2 sw=2 et
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,15 @@
 | 
				
			||||||
 | 
					return {
 | 
				
			||||||
 | 
						"windwp/nvim-autopairs",
 | 
				
			||||||
 | 
						-- Optional dependency
 | 
				
			||||||
 | 
						dependencies = { 'hrsh7th/nvim-cmp' },
 | 
				
			||||||
 | 
						config = function()
 | 
				
			||||||
 | 
							require("nvim-autopairs").setup {}
 | 
				
			||||||
 | 
							-- If you want to automatically add `(` after selecting a function or method
 | 
				
			||||||
 | 
							local cmp_autopairs = require('nvim-autopairs.completion.cmp')
 | 
				
			||||||
 | 
							local cmp = require('cmp')
 | 
				
			||||||
 | 
							cmp.event:on(
 | 
				
			||||||
 | 
								'confirm_done',
 | 
				
			||||||
 | 
								cmp_autopairs.on_confirm_done()
 | 
				
			||||||
 | 
							)
 | 
				
			||||||
 | 
						end,
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,15 @@
 | 
				
			||||||
 | 
					-- Unless you are still migrating, remove the deprecated commands from v1.x
 | 
				
			||||||
 | 
					vim.cmd([[ let g:neo_tree_remove_legacy_commands = 1 ]])
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					return {
 | 
				
			||||||
 | 
						"nvim-neo-tree/neo-tree.nvim",
 | 
				
			||||||
 | 
						version = "*",
 | 
				
			||||||
 | 
						dependencies = {
 | 
				
			||||||
 | 
							"nvim-lua/plenary.nvim",
 | 
				
			||||||
 | 
							"nvim-tree/nvim-web-devicons", -- not strictly required, but recommended
 | 
				
			||||||
 | 
							"MunifTanjim/nui.nvim",
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						config = function()
 | 
				
			||||||
 | 
							require('neo-tree').setup {}
 | 
				
			||||||
 | 
						end,
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,6 @@
 | 
				
			||||||
 | 
					return {
 | 
				
			||||||
 | 
						"kdheepak/lazygit.nvim",
 | 
				
			||||||
 | 
						dependencies = {
 | 
				
			||||||
 | 
							"nvim-lua/plenary.nvim",
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,6 @@
 | 
				
			||||||
 | 
					return {
 | 
				
			||||||
 | 
						"susensio/magic-bang.nvim",
 | 
				
			||||||
 | 
						config = true,
 | 
				
			||||||
 | 
						event = "BufNewFile",
 | 
				
			||||||
 | 
						cmd = "Bang",
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,3 @@
 | 
				
			||||||
 | 
					return {
 | 
				
			||||||
 | 
						"ixru/nvim-markdown"
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,10 @@
 | 
				
			||||||
 | 
					return {
 | 
				
			||||||
 | 
						"kylechui/nvim-surround",
 | 
				
			||||||
 | 
						version = "*", -- Use for stability; omit to use `main` branch for the latest features
 | 
				
			||||||
 | 
						event = "VeryLazy",
 | 
				
			||||||
 | 
						config = function()
 | 
				
			||||||
 | 
							require("nvim-surround").setup({
 | 
				
			||||||
 | 
								-- Configuration here, or leave empty to use defaults
 | 
				
			||||||
 | 
							})
 | 
				
			||||||
 | 
						end
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,12 @@
 | 
				
			||||||
 | 
					return {
 | 
				
			||||||
 | 
					    "astral-sh/ruff-lsp",
 | 
				
			||||||
 | 
					    config = function()
 | 
				
			||||||
 | 
					        local on_attach = function(client, bufnr)
 | 
				
			||||||
 | 
					            client.server_capabilities.hoverProvider = false
 | 
				
			||||||
 | 
					        end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        require("lspconfig").ruff_lsp.setup {
 | 
				
			||||||
 | 
					            on_attach = on_attach,
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    end
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,28 @@
 | 
				
			||||||
 | 
					-- [[ 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 })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					-- 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' })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					-- [[ 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 = '*',
 | 
				
			||||||
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					-- vim: ts=2 sts=2 sw=2 et
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,17 @@
 | 
				
			||||||
 | 
					-- [[ Install `lazy.nvim` plugin manager ]]
 | 
				
			||||||
 | 
					--    https://github.com/folke/lazy.nvim
 | 
				
			||||||
 | 
					--    `:help lazy.nvim.txt` for more info
 | 
				
			||||||
 | 
					local lazypath = vim.fn.stdpath 'data' .. '/lazy/lazy.nvim'
 | 
				
			||||||
 | 
					if not vim.loop.fs_stat(lazypath) then
 | 
				
			||||||
 | 
					  vim.fn.system {
 | 
				
			||||||
 | 
					    'git',
 | 
				
			||||||
 | 
					    'clone',
 | 
				
			||||||
 | 
					    '--filter=blob:none',
 | 
				
			||||||
 | 
					    'https://github.com/folke/lazy.nvim.git',
 | 
				
			||||||
 | 
					    '--branch=stable', -- latest stable release
 | 
				
			||||||
 | 
					    lazypath,
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					end
 | 
				
			||||||
 | 
					vim.opt.rtp:prepend(lazypath)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					-- vim: ts=2 sts=2 sw=2 et
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,215 @@
 | 
				
			||||||
 | 
					-- [[ Configure plugins ]]
 | 
				
			||||||
 | 
					-- NOTE: Here is where you install your plugins.
 | 
				
			||||||
 | 
					--  You can configure plugins using the `config` key.
 | 
				
			||||||
 | 
					--
 | 
				
			||||||
 | 
					--  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
 | 
				
			||||||
 | 
					  'tpope/vim-fugitive',
 | 
				
			||||||
 | 
					  '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', 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',
 | 
				
			||||||
 | 
					      'hrsh7th/cmp-path',
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      -- 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)
 | 
				
			||||||
 | 
					        local gs = package.loaded.gitsigns
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        local function map(mode, l, r, opts)
 | 
				
			||||||
 | 
					          opts = opts or {}
 | 
				
			||||||
 | 
					          opts.buffer = bufnr
 | 
				
			||||||
 | 
					          vim.keymap.set(mode, l, r, opts)
 | 
				
			||||||
 | 
					        end
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        -- Navigation
 | 
				
			||||||
 | 
					        map({ 'n', 'v' }, ']c', function()
 | 
				
			||||||
 | 
					          if vim.wo.diff then
 | 
				
			||||||
 | 
					            return ']c'
 | 
				
			||||||
 | 
					          end
 | 
				
			||||||
 | 
					          vim.schedule(function()
 | 
				
			||||||
 | 
					            gs.next_hunk()
 | 
				
			||||||
 | 
					          end)
 | 
				
			||||||
 | 
					          return '<Ignore>'
 | 
				
			||||||
 | 
					        end, { expr = true, desc = 'Jump to next hunk' })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        map({ 'n', 'v' }, '[c', function()
 | 
				
			||||||
 | 
					          if vim.wo.diff then
 | 
				
			||||||
 | 
					            return '[c'
 | 
				
			||||||
 | 
					          end
 | 
				
			||||||
 | 
					          vim.schedule(function()
 | 
				
			||||||
 | 
					            gs.prev_hunk()
 | 
				
			||||||
 | 
					          end)
 | 
				
			||||||
 | 
					          return '<Ignore>'
 | 
				
			||||||
 | 
					        end, { expr = true, desc = 'Jump to previous hunk' })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        -- Actions
 | 
				
			||||||
 | 
					        -- visual mode
 | 
				
			||||||
 | 
					        map('v', '<leader>hs', function()
 | 
				
			||||||
 | 
					          gs.stage_hunk { vim.fn.line '.', vim.fn.line 'v' }
 | 
				
			||||||
 | 
					        end, { desc = 'stage git hunk' })
 | 
				
			||||||
 | 
					        map('v', '<leader>hr', function()
 | 
				
			||||||
 | 
					          gs.reset_hunk { vim.fn.line '.', vim.fn.line 'v' }
 | 
				
			||||||
 | 
					        end, { desc = 'reset git hunk' })
 | 
				
			||||||
 | 
					        -- normal mode
 | 
				
			||||||
 | 
					        map('n', '<leader>hs', gs.stage_hunk, { desc = 'git stage hunk' })
 | 
				
			||||||
 | 
					        map('n', '<leader>hr', gs.reset_hunk, { desc = 'git reset hunk' })
 | 
				
			||||||
 | 
					        map('n', '<leader>hS', gs.stage_buffer, { desc = 'git Stage buffer' })
 | 
				
			||||||
 | 
					        map('n', '<leader>hu', gs.undo_stage_hunk, { desc = 'undo stage hunk' })
 | 
				
			||||||
 | 
					        map('n', '<leader>hR', gs.reset_buffer, { desc = 'git Reset buffer' })
 | 
				
			||||||
 | 
					        map('n', '<leader>hp', gs.preview_hunk, { desc = 'preview git hunk' })
 | 
				
			||||||
 | 
					        map('n', '<leader>hb', function()
 | 
				
			||||||
 | 
					          gs.blame_line { full = false }
 | 
				
			||||||
 | 
					        end, { desc = 'git blame line' })
 | 
				
			||||||
 | 
					        map('n', '<leader>hd', gs.diffthis, { desc = 'git diff against index' })
 | 
				
			||||||
 | 
					        map('n', '<leader>hD', function()
 | 
				
			||||||
 | 
					          gs.diffthis '~'
 | 
				
			||||||
 | 
					        end, { desc = 'git diff against last commit' })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        -- Toggles
 | 
				
			||||||
 | 
					        map('n', '<leader>tb', gs.toggle_current_line_blame, { desc = 'toggle git blame line' })
 | 
				
			||||||
 | 
					        map('n', '<leader>td', gs.toggle_deleted, { desc = 'toggle git show deleted' })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        -- Text object
 | 
				
			||||||
 | 
					        map({ 'o', 'x' }, 'ih', ':<C-U>Gitsigns select_hunk<CR>', { desc = 'select git hunk' })
 | 
				
			||||||
 | 
					      end,
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    -- Theme inspired by Atom
 | 
				
			||||||
 | 
					    'navarasu/onedark.nvim',
 | 
				
			||||||
 | 
					    priority = 1000,
 | 
				
			||||||
 | 
					    lazy = false,
 | 
				
			||||||
 | 
					    config = function()
 | 
				
			||||||
 | 
					      require('onedark').setup {
 | 
				
			||||||
 | 
					        -- Set a style preset. 'dark' is default.
 | 
				
			||||||
 | 
					        style = 'dark', -- dark, darker, cool, deep, warm, warmer, light
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      require('onedark').load()
 | 
				
			||||||
 | 
					    end,
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    -- Set lualine as statusline
 | 
				
			||||||
 | 
					    'nvim-lualine/lualine.nvim',
 | 
				
			||||||
 | 
					    -- See `:help lualine.txt`
 | 
				
			||||||
 | 
					    opts = {
 | 
				
			||||||
 | 
					      options = {
 | 
				
			||||||
 | 
					        icons_enabled = false,
 | 
				
			||||||
 | 
					        theme = 'auto',
 | 
				
			||||||
 | 
					        component_separators = '|',
 | 
				
			||||||
 | 
					        section_separators = '',
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  {
 | 
				
			||||||
 | 
					    -- Add indentation guides even on blank lines
 | 
				
			||||||
 | 
					    'lukas-reineke/indent-blankline.nvim',
 | 
				
			||||||
 | 
					    -- Enable `lukas-reineke/indent-blankline.nvim`
 | 
				
			||||||
 | 
					    -- See `:help ibl`
 | 
				
			||||||
 | 
					    main = 'ibl',
 | 
				
			||||||
 | 
					    opts = {},
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  -- "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' },
 | 
				
			||||||
 | 
					}, {})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					-- vim: ts=2 sts=2 sw=2 et
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,122 @@
 | 
				
			||||||
 | 
					-- [[ 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', function()
 | 
				
			||||||
 | 
					    vim.lsp.buf.code_action { context = { only = { 'quickfix', 'refactor', 'source' } } }
 | 
				
			||||||
 | 
					  end, '[C]ode [A]ction')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  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,
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					-- vim: ts=2 sts=2 sw=2 et
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,45 @@
 | 
				
			||||||
 | 
					-- [[ 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
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					-- vim: ts=2 sts=2 sw=2 et
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					-- My configuration
 | 
				
			||||||
 | 
					vim.wo.relativenumber = true
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,81 @@
 | 
				
			||||||
 | 
					-- [[ 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' })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					-- vim: ts=2 sts=2 sw=2 et
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,75 @@
 | 
				
			||||||
 | 
					-- [[ 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' },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    -- Autoinstall languages that are not installed. Defaults to false (but you can change for yourself!)
 | 
				
			||||||
 | 
					    auto_install = false,
 | 
				
			||||||
 | 
					    -- Install languages synchronously (only applied to `ensure_installed`)
 | 
				
			||||||
 | 
					    sync_install = false,
 | 
				
			||||||
 | 
					    -- List of parsers to ignore installing
 | 
				
			||||||
 | 
					    ignore_install = {},
 | 
				
			||||||
 | 
					    -- You can specify additional Treesitter modules here: -- For example: -- playground = {--enable = true,-- },
 | 
				
			||||||
 | 
					    modules = {},
 | 
				
			||||||
 | 
					    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)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					-- vim: ts=2 sts=2 sw=2 et
 | 
				
			||||||
		Loading…
	
		Reference in New Issue