6 ["g?"] = "actions.show_help",
7 ["<CR>"] = "actions.select",
8 ["<C-s>"] = "actions.select_vsplit",
9 ["<C-h>"] = false, -- used to be actions.select_split
10 ["<C-t>"] = "actions.select_tab",
11 ["<C-p>"] = "actions.preview",
12 ["<C-c>"] = "actions.close",
13 ["<C-l>"] = false, -- used to be actions.refresh
14 ["-"] = "actions.parent",
15 ["_"] = "actions.open_cwd",
17 ["~"] = "actions.tcd",
18 ["gs"] = "actions.change_sort",
19 ["gx"] = "actions.open_external",
20 ["g."] = "actions.toggle_hidden",
21 ["g\\"] = "actions.toggle_trash",
24 dependencies = {"nvim-tree/nvim-web-devicons"},
26 { "folke/trouble.nvim",
31 win = { position = "right" },
36 { "<leader>xx", "<cmd>Trouble diagnostics toggle<cr>", desc = "Diagnostics (Trouble)" },
37 { "<leader>xX", "<cmd>Trouble diagnostics toggle filter.buf=0<cr>", desc = "Buffer Diagnostics (Trouble)" },
38 { "<leader>cs", "<cmd>Trouble symbols toggle<cr>", desc = "Symbols (Trouble)" },
39 { "<leader>cS", "<cmd>Trouble lsp toggle<cr>", desc = "LSP references/definitions/... (Trouble)" },
40 { "<leader>xL", "<cmd>Trouble loclist toggle<cr>", desc = "Location List (Trouble)" },
41 { "<leader>xQ", "<cmd>Trouble qflist toggle<cr>", desc = "Quickfix List (Trouble)" },
45 if require("trouble").is_open() then
46 require("trouble").prev({ skip_groups = true, jump = true })
48 local ok, err = pcall(vim.cmd.cprev)
50 vim.notify(err, vim.log.levels.ERROR)
54 desc = "Previous Trouble/Quickfix Item",
59 if require("trouble").is_open() then
60 require("trouble").next({ skip_groups = true, jump = true })
62 local ok, err = pcall(vim.cmd.cnext)
64 vim.notify(err, vim.log.levels.ERROR)
68 desc = "Next Trouble/Quickfix Item",
72 { "folke/todo-comments.nvim",
73 -- Finds and lists all of the TODO, HACK, BUG, etc comment
74 -- in your project and loads them into a browsable list.
75 cmd = { "TodoTrouble", "TodoTelescope" },
79 { "]t", function() require("todo-comments").jump_next() end, desc = "Next Todo Comment" },
80 { "[t", function() require("todo-comments").jump_prev() end, desc = "Previous Todo Comment" },
81 { "<leader>xt", "<cmd>Trouble todo toggle<cr>", desc = "Todo (Trouble)" },
82 { "<leader>xT", "<cmd>Trouble todo toggle filter = {tag = {TODO,FIX,FIXME}}<cr>", desc = "Todo/Fix/Fixme (Trouble)" },
83 { "<leader>st", "<cmd>TodoTelescope<cr>", desc = "Todo" },
84 { "<leader>sT", "<cmd>TodoTelescope keywords=TODO,FIX,FIXME<cr>", desc = "Todo/Fix/Fixme" },
89 -- Flash enhances the built-in search functionality by showing labels
90 -- at the end of each match, letting you quickly jump to a specific
98 { "s", mode = { "n", "x", "o" }, function() require("flash").jump() end, desc = "Flash" },
99 { "S", mode = { "n", "o", "x" }, function() require("flash").treesitter() end, desc = "Flash Treesitter" },
100 { "r", mode = "o", function() require("flash").remote() end, desc = "Remote Flash" },
101 { "R", mode = { "o", "x" }, function() require("flash").treesitter_search() end, desc = "Treesitter Search" },
102 { "<c-s>", mode = { "c" }, function() require("flash").toggle() end, desc = "Toggle Flash Search" },
105 { "lewis6991/gitsigns.nvim",
106 -- git signs highlights text that has changed since the list
107 -- git commit, and also lets you interactively stage & unstage
108 -- hunks in a commit.
112 add = { text = "▎" },
113 change = { text = "▎" },
114 delete = { text = "" },
115 topdelete = { text = "" },
116 changedelete = { text = "▎" },
117 untracked = { text = "▎" },
120 add = { text = "▎" },
121 change = { text = "▎" },
122 delete = { text = "" },
123 topdelete = { text = "" },
124 changedelete = { text = "▎" },
126 on_attach = function(buffer)
127 local gs = package.loaded.gitsigns
129 local function map(mode, l, r, desc)
130 vim.keymap.set(mode, l, r, { buffer = buffer, desc = desc })
133 -- stylua: ignore start
134 map("n", "]h", function()
136 vim.cmd.normal({ "]c", bang = true })
141 map("n", "[h", function()
143 vim.cmd.normal({ "[c", bang = true })
148 map("n", "]H", function() gs.nav_hunk("last") end, "Last Hunk")
149 map("n", "[H", function() gs.nav_hunk("first") end, "First Hunk")
150 map({ "n", "v" }, "<leader>ghs", ":Gitsigns stage_hunk<CR>", "Stage Hunk")
151 map({ "n", "v" }, "<leader>ghr", ":Gitsigns reset_hunk<CR>", "Reset Hunk")
152 map("n", "<leader>ghS", gs.stage_buffer, "Stage Buffer")
153 map("n", "<leader>ghu", gs.undo_stage_hunk, "Undo Stage Hunk")
154 map("n", "<leader>ghR", gs.reset_buffer, "Reset Buffer")
155 map("n", "<leader>ghp", gs.preview_hunk_inline, "Preview Hunk Inline")
156 map("n", "<leader>ghb", function() gs.blame_line({ full = true }) end, "Blame Line")
157 map("n", "<leader>ghB", function() gs.blame() end, "Blame Buffer")
158 map("n", "<leader>ghd", gs.diffthis, "Diff This")
159 map("n", "<leader>ghD", function() gs.diffthis("~") end, "Diff This ~")
160 map({ "o", "x" }, "ih", ":<C-U>Gitsigns select_hunk<CR>", "GitSigns Select Hunk")
164 return require("gitsigns.config").config.signcolumn
166 set = function(state)
167 require("gitsigns").toggle_signs(state)
174 -- TODO: currently unused plugins, check and enable/remove
175 { "MagicDuck/grug-far.nvim", enabled = false,
176 -- search/replace in multiple files
177 opts = { headerMaxWidth = 80 },
183 local grug = require("grug-far")
184 local ext = vim.bo.buftype == "" and vim.fn.expand("%:e")
188 filesFilter = ext and ext ~= "" and "*." .. ext or nil,
193 desc = "Search and Replace",