Merge branch 'nvim-lua:master' into master
This commit is contained in:
		
						commit
						b7bbd9b1d1
					
				
							
								
								
									
										11
									
								
								README.md
								
								
								
								
							
							
						
						
									
										11
									
								
								README.md
								
								
								
								
							| 
						 | 
				
			
			@ -34,7 +34,8 @@ Neovim's configurations are located under the following paths, depending on your
 | 
			
		|||
| :- | :--- |
 | 
			
		||||
| Linux | `$XDG_CONFIG_HOME/nvim`, `~/.config/nvim` |
 | 
			
		||||
| MacOS | `$XDG_CONFIG_HOME/nvim`, `~/.config/nvim` |
 | 
			
		||||
| Windows | `%userprofile%\AppData\Local\nvim\` |
 | 
			
		||||
| Windows (cmd)| `%userprofile%\AppData\Local\nvim\` |
 | 
			
		||||
| Windows (powershell)| `$env:USERPROFILE\AppData\Local\nvim\` |
 | 
			
		||||
 | 
			
		||||
Clone kickstart.nvim:
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -45,10 +46,16 @@ git clone https://github.com/nvim-lua/kickstart.nvim.git "${XDG_CONFIG_HOME:-$HO
 | 
			
		|||
 | 
			
		||||
 | 
			
		||||
```
 | 
			
		||||
# on Windows
 | 
			
		||||
# on Windows (cmd)
 | 
			
		||||
git clone https://github.com/nvim-lua/kickstart.nvim.git %userprofile%\AppData\Local\nvim\ 
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
```
 | 
			
		||||
# on Windows (powershell)
 | 
			
		||||
git clone https://github.com/nvim-lua/kickstart.nvim.git $env:USERPROFILE\AppData\Local\nvim\ 
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
### Post Installation
 | 
			
		||||
 | 
			
		||||
Start Neovim
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
							
								
								
									
										53
									
								
								init.lua
								
								
								
								
							
							
						
						
									
										53
									
								
								init.lua
								
								
								
								
							| 
						 | 
				
			
			@ -37,13 +37,14 @@ I hope you enjoy your Neovim journey,
 | 
			
		|||
 | 
			
		||||
P.S. You can delete this when you're done too. It's your config now :)
 | 
			
		||||
--]]
 | 
			
		||||
 | 
			
		||||
-- Set <space> as the leader key
 | 
			
		||||
-- See `:help mapleader`
 | 
			
		||||
--  NOTE: Must happen before plugins are required (otherwise wrong leader will be used)
 | 
			
		||||
vim.g.mapleader = ' '
 | 
			
		||||
vim.g.maplocalleader = ' '
 | 
			
		||||
 | 
			
		||||
-- Install package manager
 | 
			
		||||
-- [[ 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'
 | 
			
		||||
| 
						 | 
				
			
			@ -59,6 +60,7 @@ if not vim.loop.fs_stat(lazypath) then
 | 
			
		|||
end
 | 
			
		||||
vim.opt.rtp:prepend(lazypath)
 | 
			
		||||
 | 
			
		||||
-- [[ Configure plugins ]]
 | 
			
		||||
-- NOTE: Here is where you install your plugins.
 | 
			
		||||
--  You can configure plugins using the `config` key.
 | 
			
		||||
--
 | 
			
		||||
| 
						 | 
				
			
			@ -281,6 +283,12 @@ vim.keymap.set({ 'n', 'v' }, '<Space>', '<Nop>', { silent = true })
 | 
			
		|||
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 })
 | 
			
		||||
| 
						 | 
				
			
			@ -308,6 +316,42 @@ require('telescope').setup {
 | 
			
		|||
-- 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' })
 | 
			
		||||
| 
						 | 
				
			
			@ -324,6 +368,7 @@ vim.keymap.set('n', '<leader>sf', require('telescope.builtin').find_files, { des
 | 
			
		|||
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' })
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -396,12 +441,6 @@ vim.defer_fn(function()
 | 
			
		|||
  }
 | 
			
		||||
end, 0)
 | 
			
		||||
 | 
			
		||||
-- Diagnostic keymaps
 | 
			
		||||
vim.keymap.set('n', '[d', vim.diagnostic.goto_prev, { desc = 'Go to previous diagnostic message' })
 | 
			
		||||
vim.keymap.set('n', ']d', vim.diagnostic.goto_next, { desc = 'Go to next diagnostic message' })
 | 
			
		||||
vim.keymap.set('n', '<leader>e', vim.diagnostic.open_float, { desc = 'Open floating diagnostic message' })
 | 
			
		||||
vim.keymap.set('n', '<leader>q', vim.diagnostic.setloclist, { desc = 'Open diagnostics list' })
 | 
			
		||||
 | 
			
		||||
-- [[ Configure LSP ]]
 | 
			
		||||
--  This function gets run when an LSP connects to a particular buffer.
 | 
			
		||||
local on_attach = function(_, bufnr)
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in New Issue