diff options
author | Damjan 9000 <damjan.9000@gmail.com> | 2023-11-07 10:12:55 +0100 |
---|---|---|
committer | Damjan 9000 <damjan.9000@gmail.com> | 2023-11-07 10:12:55 +0100 |
commit | 0d1f2c56395b5614f10fffc065eb05b36dc202c9 (patch) | |
tree | b14e5cc457a621e8e1830a0f1b0df1404a082f3a /lua | |
parent | ae9617bcd2d7c7a2aa1830e08f3a9c03fa38c8fa (diff) | |
parent | 47974f7db1e862fa0fe7891a6c34ba1427ab5218 (diff) |
Merge remote-tracking branch 'upstream/master'
- Telescope live_grep on Git root
- Update README.md: windows powershell
Diffstat (limited to 'lua')
-rw-r--r-- | lua/telescope-setup.lua | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/lua/telescope-setup.lua b/lua/telescope-setup.lua index be34051..b467605 100644 --- a/lua/telescope-setup.lua +++ b/lua/telescope-setup.lua @@ -14,6 +14,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' }) @@ -30,6 +66,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' }) |