Merge branch 'nvim-lua:master' into master
This commit is contained in:
		
						commit
						3745d242ba
					
				| 
						 | 
				
			
			@ -0,0 +1,18 @@
 | 
			
		|||
# Check Lua Formatting
 | 
			
		||||
name: Check Lua Formatting
 | 
			
		||||
on: pull_request
 | 
			
		||||
 | 
			
		||||
jobs:
 | 
			
		||||
  stylua-check:
 | 
			
		||||
    name: Stylua Check
 | 
			
		||||
    runs-on: ubuntu-latest
 | 
			
		||||
    steps:
 | 
			
		||||
      - name: Checkout Code
 | 
			
		||||
        uses: actions/checkout@v2
 | 
			
		||||
      - name: Stylua Check
 | 
			
		||||
        uses: JohnnyMorganz/stylua-action@v3
 | 
			
		||||
        with:
 | 
			
		||||
          token: ${{ secrets.GITHUB_TOKEN }}
 | 
			
		||||
          version: latest
 | 
			
		||||
          args: --check .
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										14
									
								
								README.md
								
								
								
								
							
							
						
						
									
										14
									
								
								README.md
								
								
								
								
							| 
						 | 
				
			
			@ -39,19 +39,18 @@ Neovim's configurations are located under the following paths, depending on your
 | 
			
		|||
 | 
			
		||||
Clone kickstart.nvim:
 | 
			
		||||
 | 
			
		||||
- on Linux and Mac
 | 
			
		||||
```sh
 | 
			
		||||
# on Linux and Mac
 | 
			
		||||
git clone https://github.com/nvim-lua/kickstart.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\ 
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
- on Windows (powershell)
 | 
			
		||||
```
 | 
			
		||||
# on Windows (powershell)
 | 
			
		||||
git clone https://github.com/nvim-lua/kickstart.nvim.git $env:USERPROFILE\AppData\Local\nvim\ 
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -157,12 +156,11 @@ Each PR, especially those which increase the line count, should have a descripti
 | 
			
		|||
  * This includes your existing init.lua and the neovim files in `~/.local` which can be deleted with `rm -rf ~/.local/share/nvim/`
 | 
			
		||||
  * You may also want to look at the [migration guide for lazy.nvim](https://github.com/folke/lazy.nvim#-migration-guide)
 | 
			
		||||
* Can I keep my existing configuration in parallel to kickstart?
 | 
			
		||||
  * Yes! You can use [NVIM_APPNAME](https://neovim.io/doc/user/starting.html#%24NVIM_APPNAME)`=nvim-NAME` to maintain multiple configurations. For example you can install the kickstart configuration in `~/.config/nvim-kickstart` and create a script `~/bin/nvim-kickstart`:
 | 
			
		||||
  * Yes! You can use [NVIM_APPNAME](https://neovim.io/doc/user/starting.html#%24NVIM_APPNAME)`=nvim-NAME` to maintain multiple configurations. For example you can install the kickstart configuration in `~/.config/nvim-kickstart` and create an alias:
 | 
			
		||||
    ```
 | 
			
		||||
    #!/bin/sh
 | 
			
		||||
    exec env NVIM_APPNAME=nvim-kickstart nvim "$@"
 | 
			
		||||
    alias nvim-kickstart='NVIM_APPNAME="nvim-kickstart" nvim'
 | 
			
		||||
    ```
 | 
			
		||||
    When you run Neovim with `nvim-kickstart` it will use the alternative config directory and the matching local directory: `~/.local/share/nvim-kickstart`. You can apply this approach to any Neovim distribution that you would like to try out.
 | 
			
		||||
    When you run Neovim using `nvim-kickstart` alias it will use the alternative config directory and the matching local directory `~/.local/share/nvim-kickstart`. You can apply this approach to any Neovim distribution that you would like to try out.
 | 
			
		||||
* What if I want to "uninstall" this configuration:
 | 
			
		||||
  * See [lazy.nvim uninstall](https://github.com/folke/lazy.nvim#-uninstalling) information
 | 
			
		||||
* Are there any cool videos about this plugin?
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
							
								
								
									
										85
									
								
								init.lua
								
								
								
								
							
							
						
						
									
										85
									
								
								init.lua
								
								
								
								
							| 
						 | 
				
			
			@ -105,6 +105,7 @@ require('lazy').setup({
 | 
			
		|||
 | 
			
		||||
      -- Adds LSP completion capabilities
 | 
			
		||||
      'hrsh7th/cmp-nvim-lsp',
 | 
			
		||||
      'hrsh7th/cmp-path',
 | 
			
		||||
 | 
			
		||||
      -- Adds a number of user-friendly snippets
 | 
			
		||||
      'rafamadriz/friendly-snippets',
 | 
			
		||||
| 
						 | 
				
			
			@ -126,11 +127,16 @@ require('lazy').setup({
 | 
			
		|||
        changedelete = { text = '~' },
 | 
			
		||||
      },
 | 
			
		||||
      on_attach = function(bufnr)
 | 
			
		||||
        vim.keymap.set('n', '<leader>hp', require('gitsigns').preview_hunk, { buffer = bufnr, desc = 'Preview git hunk' })
 | 
			
		||||
 | 
			
		||||
        -- don't override the built-in and fugitive keymaps
 | 
			
		||||
        local gs = package.loaded.gitsigns
 | 
			
		||||
        vim.keymap.set({ 'n', 'v' }, ']c', function()
 | 
			
		||||
 | 
			
		||||
        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
 | 
			
		||||
| 
						 | 
				
			
			@ -138,8 +144,9 @@ require('lazy').setup({
 | 
			
		|||
            gs.next_hunk()
 | 
			
		||||
          end)
 | 
			
		||||
          return '<Ignore>'
 | 
			
		||||
        end, { expr = true, buffer = bufnr, desc = 'Jump to next hunk' })
 | 
			
		||||
        vim.keymap.set({ 'n', 'v' }, '[c', function()
 | 
			
		||||
        end, { expr = true, desc = 'Jump to next hunk' })
 | 
			
		||||
 | 
			
		||||
        map({ 'n', 'v' }, '[c', function()
 | 
			
		||||
          if vim.wo.diff then
 | 
			
		||||
            return '[c'
 | 
			
		||||
          end
 | 
			
		||||
| 
						 | 
				
			
			@ -147,7 +154,37 @@ require('lazy').setup({
 | 
			
		|||
            gs.prev_hunk()
 | 
			
		||||
          end)
 | 
			
		||||
          return '<Ignore>'
 | 
			
		||||
        end, { expr = true, buffer = bufnr, desc = 'Jump to previous hunk' })
 | 
			
		||||
        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,
 | 
			
		||||
    },
 | 
			
		||||
  },
 | 
			
		||||
| 
						 | 
				
			
			@ -329,17 +366,17 @@ local function find_git_root()
 | 
			
		|||
  local current_dir
 | 
			
		||||
  local cwd = vim.fn.getcwd()
 | 
			
		||||
  -- If the buffer is not associated with a file, return nil
 | 
			
		||||
  if current_file == "" then
 | 
			
		||||
  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")
 | 
			
		||||
    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]
 | 
			
		||||
  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")
 | 
			
		||||
    print 'Not a git repository. Searching on current working directory'
 | 
			
		||||
    return cwd
 | 
			
		||||
  end
 | 
			
		||||
  return git_root
 | 
			
		||||
| 
						 | 
				
			
			@ -349,9 +386,9 @@ end
 | 
			
		|||
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},
 | 
			
		||||
    })
 | 
			
		||||
    require('telescope.builtin').live_grep {
 | 
			
		||||
      search_dirs = { git_root },
 | 
			
		||||
    }
 | 
			
		||||
  end
 | 
			
		||||
end
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -368,6 +405,14 @@ vim.keymap.set('n', '<leader>/', function()
 | 
			
		|||
  })
 | 
			
		||||
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' })
 | 
			
		||||
| 
						 | 
				
			
			@ -496,11 +541,18 @@ 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 = 'More git', _ = '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.
 | 
			
		||||
| 
						 | 
				
			
			@ -572,7 +624,7 @@ cmp.setup {
 | 
			
		|||
    end,
 | 
			
		||||
  },
 | 
			
		||||
  completion = {
 | 
			
		||||
    completeopt = 'menu,menuone,noinsert'
 | 
			
		||||
    completeopt = 'menu,menuone,noinsert',
 | 
			
		||||
  },
 | 
			
		||||
  mapping = cmp.mapping.preset.insert {
 | 
			
		||||
    ['<C-n>'] = cmp.mapping.select_next_item(),
 | 
			
		||||
| 
						 | 
				
			
			@ -606,6 +658,7 @@ cmp.setup {
 | 
			
		|||
  sources = {
 | 
			
		||||
    { name = 'nvim_lsp' },
 | 
			
		||||
    { name = 'luasnip' },
 | 
			
		||||
    { name = 'path' },
 | 
			
		||||
  },
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in New Issue