Compare commits
32 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 822b092d15 | |||
| 6fa41890ab | |||
| 0066e28c8f | |||
| 3f08c78c13 | |||
| d6f6f9e11d | |||
| 19c17b583b | |||
| 8638342fa9 | |||
| a62a601e1f | |||
|
|
44a24e2fe5 | ||
|
|
1a98a451ea | ||
|
|
ccf6bc397f | ||
|
|
13cce81d99 | ||
|
|
8fe6a6560e | ||
| fe912ab5fb | |||
|
|
0dcd8a91b6 | ||
|
|
e9f6957b99 | ||
|
|
8aec881517 | ||
|
|
f17e83010f | ||
|
|
282a23f446 | ||
|
|
c80f3f0501 | ||
|
|
c2ec317b1b | ||
|
|
2fedda14ed | ||
|
|
e121bde8d8 | ||
|
|
9bb7dcbaf4 | ||
|
|
c8777040fb | ||
| 86ccf3bb2d | |||
| 8d2bf49223 | |||
| 8d535ad186 | |||
| 25bc8e05c4 | |||
| 29a0d2ee30 | |||
| 722044c88a | |||
| b933fbe1d9 |
2
.gitignore
vendored
2
.gitignore
vendored
@ -1,5 +1,3 @@
|
|||||||
plugin
|
|
||||||
custom
|
|
||||||
spell
|
spell
|
||||||
ftplugin
|
ftplugin
|
||||||
syntax
|
syntax
|
||||||
|
|||||||
11
after/syntax/diff.vim
Normal file
11
after/syntax/diff.vim
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
" hi DiffAdd gui=none guifg=NONE guibg=#bada9f
|
||||||
|
" hi DiffChange gui=none guifg=NONE guibg=#e5d5ac
|
||||||
|
" hi DiffDelete gui=bold guifg=#ff8080 guibg=#ffb0b0
|
||||||
|
" hi DiffText gui=none guifg=NONE guibg=#8cbee2
|
||||||
|
hi DiffAdd gui=none guifg=NONE guibg=#003200
|
||||||
|
hi DiffChange gui=none guifg=NONE guibg=#000032
|
||||||
|
hi DiffDelete gui=bold guifg=#ff8080 guibg=#602020
|
||||||
|
hi DiffText gui=bold guifg=NONE guibg=#102040
|
||||||
|
hi link @text.diff.add DiffAdd
|
||||||
|
hi link @text.diff.delete DiffDelete
|
||||||
|
hi link @text.diff.change DiffChange
|
||||||
2
init.lua
2
init.lua
@ -18,4 +18,6 @@ end
|
|||||||
|
|
||||||
dofile(vim.g.base46_cache .. "defaults")
|
dofile(vim.g.base46_cache .. "defaults")
|
||||||
vim.opt.rtp:prepend(lazypath)
|
vim.opt.rtp:prepend(lazypath)
|
||||||
|
vim.api.nvim_command "packadd cfilter"
|
||||||
|
vim.api.nvim_command "packadd justify"
|
||||||
require "plugins"
|
require "plugins"
|
||||||
|
|||||||
@ -40,13 +40,6 @@ M.gen_chadrc_template = function()
|
|||||||
local path = fn.stdpath "config" .. "/lua/custom"
|
local path = fn.stdpath "config" .. "/lua/custom"
|
||||||
|
|
||||||
if fn.isdirectory(path) ~= 1 then
|
if fn.isdirectory(path) ~= 1 then
|
||||||
local input = fn.input "Do you want to install example custom config? (y/N): "
|
|
||||||
|
|
||||||
if input:lower() == "y" then
|
|
||||||
M.echo "Cloning example custom config repo..."
|
|
||||||
shell_call { "git", "clone", "--depth", "1", "https://github.com/NvChad/example_config", path }
|
|
||||||
fn.delete(path .. "/.git", "rf")
|
|
||||||
else
|
|
||||||
-- use very minimal chadrc
|
-- use very minimal chadrc
|
||||||
fn.mkdir(path, "p")
|
fn.mkdir(path, "p")
|
||||||
|
|
||||||
@ -57,6 +50,5 @@ M.gen_chadrc_template = function()
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
return M
|
return M
|
||||||
|
|||||||
@ -10,9 +10,9 @@ M.ui = {
|
|||||||
hl_add = {},
|
hl_add = {},
|
||||||
hl_override = {},
|
hl_override = {},
|
||||||
changed_themes = {},
|
changed_themes = {},
|
||||||
theme_toggle = { "onedark", "one_light" },
|
theme_toggle = { "gatekeeper", "one_light" },
|
||||||
theme = "onedark", -- default theme
|
theme = "gatekeeper", -- default theme
|
||||||
transparency = false,
|
transparency = true,
|
||||||
lsp_semantic_tokens = false, -- needs nvim v0.9, just adds highlight groups for lsp semantic tokens
|
lsp_semantic_tokens = false, -- needs nvim v0.9, just adds highlight groups for lsp semantic tokens
|
||||||
|
|
||||||
-- https://github.com/NvChad/base46/tree/v2.0/lua/base46/extended_integrations
|
-- https://github.com/NvChad/base46/tree/v2.0/lua/base46/extended_integrations
|
||||||
@ -35,7 +35,6 @@ M.ui = {
|
|||||||
-- default/round/block/arrow separators work only for default statusline theme
|
-- default/round/block/arrow separators work only for default statusline theme
|
||||||
-- round and block will work for minimal theme only
|
-- round and block will work for minimal theme only
|
||||||
separator_style = "default",
|
separator_style = "default",
|
||||||
overriden_modules = nil,
|
|
||||||
},
|
},
|
||||||
|
|
||||||
-- lazyload it when there are 1+ buffers
|
-- lazyload it when there are 1+ buffers
|
||||||
@ -65,7 +64,7 @@ M.ui = {
|
|||||||
buttons = {
|
buttons = {
|
||||||
{ " Find File", "Spc f f", "Telescope find_files" },
|
{ " Find File", "Spc f f", "Telescope find_files" },
|
||||||
{ " Recent Files", "Spc f o", "Telescope oldfiles" },
|
{ " Recent Files", "Spc f o", "Telescope oldfiles" },
|
||||||
{ " Find Word", "Spc f w", "Telescope live_grep" },
|
{ " Find Word", "Spc f w", "Telescope find_grep" },
|
||||||
{ " Bookmarks", "Spc m a", "Telescope marks" },
|
{ " Bookmarks", "Spc m a", "Telescope marks" },
|
||||||
{ " Themes", "Spc t h", "Telescope themes" },
|
{ " Themes", "Spc t h", "Telescope themes" },
|
||||||
{ " Mappings", "Spc c h", "NvCheatsheet" },
|
{ " Mappings", "Spc c h", "NvCheatsheet" },
|
||||||
|
|||||||
@ -6,7 +6,7 @@ local config = require("core.utils").load_config()
|
|||||||
g.nvchad_theme = config.ui.theme
|
g.nvchad_theme = config.ui.theme
|
||||||
g.base46_cache = vim.fn.stdpath "data" .. "/nvchad/base46/"
|
g.base46_cache = vim.fn.stdpath "data" .. "/nvchad/base46/"
|
||||||
g.toggle_theme_icon = " "
|
g.toggle_theme_icon = " "
|
||||||
g.transparency = config.ui.transparency
|
g.transparency = true
|
||||||
|
|
||||||
-------------------------------------- options ------------------------------------------
|
-------------------------------------- options ------------------------------------------
|
||||||
opt.laststatus = 3 -- global statusline
|
opt.laststatus = 3 -- global statusline
|
||||||
@ -17,10 +17,10 @@ opt.cursorline = true
|
|||||||
|
|
||||||
-- Indenting
|
-- Indenting
|
||||||
opt.expandtab = true
|
opt.expandtab = true
|
||||||
opt.shiftwidth = 2
|
opt.shiftwidth = 4
|
||||||
opt.smartindent = true
|
opt.smartindent = true
|
||||||
opt.tabstop = 2
|
opt.tabstop = 4
|
||||||
opt.softtabstop = 2
|
opt.softtabstop = 4
|
||||||
|
|
||||||
opt.fillchars = { eob = " " }
|
opt.fillchars = { eob = " " }
|
||||||
opt.ignorecase = true
|
opt.ignorecase = true
|
||||||
@ -31,6 +31,7 @@ opt.mouse = "a"
|
|||||||
opt.number = true
|
opt.number = true
|
||||||
opt.numberwidth = 2
|
opt.numberwidth = 2
|
||||||
opt.ruler = false
|
opt.ruler = false
|
||||||
|
opt.relativenumber = true
|
||||||
|
|
||||||
-- disable nvim intro
|
-- disable nvim intro
|
||||||
opt.shortmess:append "sI"
|
opt.shortmess:append "sI"
|
||||||
@ -41,6 +42,9 @@ opt.splitright = true
|
|||||||
opt.termguicolors = true
|
opt.termguicolors = true
|
||||||
opt.timeoutlen = 400
|
opt.timeoutlen = 400
|
||||||
opt.undofile = true
|
opt.undofile = true
|
||||||
|
opt.scrolloff = 15
|
||||||
|
|
||||||
|
opt.wildignore:append "tags,Session.vim"
|
||||||
|
|
||||||
-- interval for writing swap file to disk, also used by gitsigns
|
-- interval for writing swap file to disk, also used by gitsigns
|
||||||
opt.updatetime = 250
|
opt.updatetime = 250
|
||||||
@ -57,7 +61,7 @@ for _, provider in ipairs { "node", "perl", "python3", "ruby" } do
|
|||||||
end
|
end
|
||||||
|
|
||||||
-- add binaries installed by mason.nvim to path
|
-- add binaries installed by mason.nvim to path
|
||||||
local is_windows = vim.loop.os_uname().sysname == "Windows_NT"
|
local is_windows = vim.fn.has "win32" ~= 0
|
||||||
vim.env.PATH = vim.fn.stdpath "data" .. "/mason/bin" .. (is_windows and ";" or ":") .. vim.env.PATH
|
vim.env.PATH = vim.fn.stdpath "data" .. "/mason/bin" .. (is_windows and ";" or ":") .. vim.env.PATH
|
||||||
|
|
||||||
-------------------------------------- autocmds ------------------------------------------
|
-------------------------------------- autocmds ------------------------------------------
|
||||||
@ -91,6 +95,7 @@ autocmd("BufWritePost", {
|
|||||||
|
|
||||||
vim.g.nvchad_theme = config.ui.theme
|
vim.g.nvchad_theme = config.ui.theme
|
||||||
vim.g.transparency = config.ui.transparency
|
vim.g.transparency = config.ui.transparency
|
||||||
|
vim.g.transparency = true
|
||||||
|
|
||||||
-- statusline
|
-- statusline
|
||||||
require("plenary.reload").reload_module("nvchad.statusline." .. config.ui.statusline.theme)
|
require("plenary.reload").reload_module("nvchad.statusline." .. config.ui.statusline.theme)
|
||||||
@ -107,6 +112,32 @@ autocmd("BufWritePost", {
|
|||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
-- user event that loads after UIEnter + only if file buf is there
|
||||||
|
vim.api.nvim_create_autocmd({ "UIEnter", "BufReadPost", "BufNewFile" }, {
|
||||||
|
group = vim.api.nvim_create_augroup("NvFilePost", { clear = true }),
|
||||||
|
callback = function(args)
|
||||||
|
local file = vim.api.nvim_buf_get_name(args.buf)
|
||||||
|
local buftype = vim.api.nvim_buf_get_option(args.buf, "buftype")
|
||||||
|
|
||||||
|
if not vim.g.ui_entered and args.event == "UIEnter" then
|
||||||
|
vim.g.ui_entered = true
|
||||||
|
end
|
||||||
|
|
||||||
|
if file ~= "" and buftype ~= "nofile" and vim.g.ui_entered then
|
||||||
|
vim.api.nvim_exec_autocmds("User", { pattern = "FilePost", modeline = false })
|
||||||
|
vim.api.nvim_del_augroup_by_name "NvFilePost"
|
||||||
|
|
||||||
|
vim.schedule(function()
|
||||||
|
vim.api.nvim_exec_autocmds("FileType", {})
|
||||||
|
|
||||||
|
if vim.g.editorconfig then
|
||||||
|
require("editorconfig").config(args.buf)
|
||||||
|
end
|
||||||
|
end, 0)
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
-------------------------------------- commands ------------------------------------------
|
-------------------------------------- commands ------------------------------------------
|
||||||
local new_cmd = vim.api.nvim_create_user_command
|
local new_cmd = vim.api.nvim_create_user_command
|
||||||
|
|
||||||
|
|||||||
@ -16,6 +16,8 @@ M.general = {
|
|||||||
},
|
},
|
||||||
|
|
||||||
n = {
|
n = {
|
||||||
|
["<leader>n"] = { ":noh <CR>", "Clear highlights" },
|
||||||
|
["<leader>rr"] = { ":source $MYVIMRC<CR>", "Reload config file" },
|
||||||
["<Esc>"] = { "<cmd> noh <CR>", "Clear highlights" },
|
["<Esc>"] = { "<cmd> noh <CR>", "Clear highlights" },
|
||||||
-- switch between windows
|
-- switch between windows
|
||||||
["<C-h>"] = { "<C-w>h", "Window left" },
|
["<C-h>"] = { "<C-w>h", "Window left" },
|
||||||
@ -23,28 +25,68 @@ M.general = {
|
|||||||
["<C-j>"] = { "<C-w>j", "Window down" },
|
["<C-j>"] = { "<C-w>j", "Window down" },
|
||||||
["<C-k>"] = { "<C-w>k", "Window up" },
|
["<C-k>"] = { "<C-w>k", "Window up" },
|
||||||
|
|
||||||
|
-- ["<C-d>"] = { "<cmd> tab Git diff %<CR>", "Git diff this file" },
|
||||||
|
["<C-d>"] = { "<cmd> DiffviewOpen -- %<CR>", "Git diff this file" },
|
||||||
|
["<C-o>"] = { "<cmd> DiffviewFileHistory %<CR>", "Git history diff this file" },
|
||||||
|
["<C-a-d>"] = { "<cmd> DiffviewClose<CR>", "Close git diff" },
|
||||||
|
-- ["<C-p>"] = { "<cmd> tab Git diff<CR>", "Git diff global" },
|
||||||
|
["<C-p>"] = { "<cmd> DiffviewOpen<CR>", "Git diff global" },
|
||||||
|
["<a-p>"] = { ":DiffviewOpen HEAD~", "Show last N commits" },
|
||||||
|
["<leader>gd"] = { "<cmd> DiffviewClose<CR>", "Git diff close" },
|
||||||
|
|
||||||
-- save
|
-- save
|
||||||
["<C-s>"] = { "<cmd> w <CR>", "Save file" },
|
["<C-s>"] = { "<cmd> w <CR>", "Save file" },
|
||||||
|
|
||||||
-- Copy all
|
-- Copy all
|
||||||
["<C-c>"] = { "<cmd> %y+ <CR>", "Copy whole file" },
|
-- ["<C-c>"] = { "<cmd> %y+ <CR>", "Copy whole file" },
|
||||||
|
|
||||||
|
-- Quit
|
||||||
|
["<C-q>"] = { "<cmd> q! <CR>", "Force quit window" },
|
||||||
|
|
||||||
-- line numbers
|
-- line numbers
|
||||||
["<leader>n"] = { "<cmd> set nu! <CR>", "Toggle line number" },
|
-- ["<leader>n"] = { "<cmd> set nu! <CR>", "Toggle line number" },
|
||||||
["<leader>rn"] = { "<cmd> set rnu! <CR>", "Toggle relative number" },
|
-- ["<leader>rn"] = { "<cmd> set rnu! <CR>", "Toggle relative number" },
|
||||||
|
|
||||||
-- Allow moving the cursor through wrapped lines with j, k, <Up> and <Down>
|
-- allow moving the cursor through wrapped lines with j, k, <Up> and <Down>
|
||||||
-- http://www.reddit.com/r/vim/comments/2k4cbr/problem_with_gj_and_gk/
|
-- http://www.reddit.com/r/vim/comments/2k4cbr/problem_with_gj_and_gk/
|
||||||
-- empty mode is same as using <cmd> :map
|
-- empty mode is same as using <cmd> :map
|
||||||
-- also don't use g[j|k] when in operator pending mode, so it doesn't alter d, y or c behaviour
|
-- also don't use g[j|k] when in operator pending mode, so it doesn't alter d, y or c behaviour
|
||||||
["j"] = { 'v:count || mode(1)[0:1] == "no" ? "j" : "gj"', "Move down", opts = { expr = true } },
|
-- ["j"] = { 'v:count || mode(1)[0:1] == "no" ? "j" : "gj"', "Move down", opts = { expr = true } },
|
||||||
["k"] = { 'v:count || mode(1)[0:1] == "no" ? "k" : "gk"', "Move up", opts = { expr = true } },
|
-- ["k"] = { 'v:count || mode(1)[0:1] == "no" ? "k" : "gk"', "Move up", opts = { expr = true } },
|
||||||
["<Up>"] = { 'v:count || mode(1)[0:1] == "no" ? "k" : "gk"', "Move up", opts = { expr = true } },
|
-- ["<Up>"] = { 'v:count || mode(1)[0:1] == "no" ? "k" : "gk"', "Move up", opts = { expr = true } },
|
||||||
["<Down>"] = { 'v:count || mode(1)[0:1] == "no" ? "j" : "gj"', "Move down", opts = { expr = true } },
|
-- ["<Down>"] = { 'v:count || mode(1)[0:1] == "no" ? "j" : "gj"', "Move down", opts = { expr = true } },
|
||||||
|
|
||||||
|
-- ["<leader>y"] = {"<cmd> :w! /tmp/vimtmp<CR>", "Save into a global tmp file"},
|
||||||
|
-- ["<leader>p"] = {"<cmd> :r! cat /tmp/vimtmp<CR>", "Restore from the global tmp file"},
|
||||||
|
|
||||||
|
-- (Double) Trouble
|
||||||
|
["<leader>tx"] = { ":Trouble diagnostics toggle<CR>", "[T]rouble diagnostics" },
|
||||||
|
["<leader>tX"] = { ":Trouble diagnostics toggle filter.buf=0<CR>", "[T]rouble buffer diagnostics" },
|
||||||
|
["<leader>ts"] = { ":Trouble symbols toggle focus=false<CR>", "[T]rouble [S]ymbols" },
|
||||||
|
["<leader>tl"] = { ":Trouble lsp toggle focus=false win.position=right<CR>", "[T]rouble [L]sp def / ref / ..." },
|
||||||
|
["<leader>tL"] = { ":Trouble loclist toggle<CR>", "[T]rouble [L]oclist" },
|
||||||
|
["<leader>tQ"] = { ":Trouble qflist toggle<CR>", "[T]rouble [Q]uickfix" },
|
||||||
|
|
||||||
|
["<leader>dgg"] = { ":lua require('dap').continue() <CR>", "Continue debu[g]ging" },
|
||||||
|
["<leader>dg<CR>"] = { ":lua require('dapui').toggle() <CR>", "Toggle DAP ui" },
|
||||||
|
["<leader>dgw"] = { ":lua require('dapui').eval() <CR>", "Open floating windows about current [w]ord" },
|
||||||
|
["<leader>dgb"] = { ":lua require('dap').toggle_breakpoint() <CR>", "Toggle [b]reakpoint" },
|
||||||
|
["<leader>dgf"] = { ":lua require('dap-python').test_method() <CR>", "Debug [f]unction" },
|
||||||
|
["<leader>dgo"] = { ":lua require('dap').step_over() <CR>", "DAP step [o]ver method" },
|
||||||
|
["<leader>dgt"] = { ":lua require('dap').step_into() <CR>", "DAP step in[t]o method" },
|
||||||
|
["<leader>dgp"] = { ":lua require('dap').step_back() <CR>", "DAP step back ([p]revious)" },
|
||||||
|
["<leader>dgs"] = {
|
||||||
|
function()
|
||||||
|
local widgets = require "dap.ui.widgets"
|
||||||
|
local sidebar = widgets.sidebar(widgets.scopes)
|
||||||
|
sidebar.open { widgth = "50%" }
|
||||||
|
end,
|
||||||
|
"DAP Show debugged [s]copes",
|
||||||
|
},
|
||||||
|
|
||||||
-- new buffer
|
-- new buffer
|
||||||
["<leader>b"] = { "<cmd> enew <CR>", "New buffer" },
|
-- ["<leader>b"] = { "<cmd> enew <CR>", "New buffer" },
|
||||||
["<leader>ch"] = { "<cmd> NvCheatsheet <CR>", "Mapping cheatsheet" },
|
-- ["<leader>ch"] = { "<cmd> NvCheatsheet <CR>", "Mapping cheatsheet" },
|
||||||
|
|
||||||
["<leader>fm"] = {
|
["<leader>fm"] = {
|
||||||
function()
|
function()
|
||||||
@ -59,21 +101,120 @@ M.general = {
|
|||||||
},
|
},
|
||||||
|
|
||||||
v = {
|
v = {
|
||||||
["<Up>"] = { 'v:count || mode(1)[0:1] == "no" ? "k" : "gk"', "Move up", opts = { expr = true } },
|
-- ["<Up>"] = { 'v:count || mode(1)[0:1] == "no" ? "k" : "gk"', "Move up", opts = { expr = true } },
|
||||||
["<Down>"] = { 'v:count || mode(1)[0:1] == "no" ? "j" : "gj"', "Move down", opts = { expr = true } },
|
-- ["<Down>"] = { 'v:count || mode(1)[0:1] == "no" ? "j" : "gj"', "Move down", opts = { expr = true } },
|
||||||
["<"] = { "<gv", "Indent line" },
|
["<"] = { "<gv", "Indent line" },
|
||||||
[">"] = { ">gv", "Indent line" },
|
[">"] = { ">gv", "Indent line" },
|
||||||
|
|
||||||
|
["<leader>dgd"] = { ":lua require('dap-python').debug_selection()", "DAP debug selection" },
|
||||||
|
["<leader>dgw"] = { ":lua require('dap-python').eval()", "DAP eval selection" },
|
||||||
},
|
},
|
||||||
|
|
||||||
x = {
|
x = {
|
||||||
["j"] = { 'v:count || mode(1)[0:1] == "no" ? "j" : "gj"', "Move down", opts = { expr = true } },
|
-- ["j"] = { 'v:count || mode(1)[0:1] == "no" ? "j" : "gj"', "Move down", opts = { expr = true } },
|
||||||
["k"] = { 'v:count || mode(1)[0:1] == "no" ? "k" : "gk"', "Move up", opts = { expr = true } },
|
-- ["k"] = { 'v:count || mode(1)[0:1] == "no" ? "k" : "gk"', "Move up", opts = { expr = true } },
|
||||||
-- Don't copy the replaced text after pasting in visual mode
|
-- Don't copy the replaced text after pasting in visual mode
|
||||||
-- https://vim.fandom.com/wiki/Replace_a_word_with_yanked_text#Alternative_mapping_for_paste
|
-- https://vim.fandom.com/wiki/Replace_a_word_with_yanked_text#alternative_mapping_for_paste
|
||||||
["p"] = { 'p:let @+=@0<CR>:let @"=@0<CR>', "Dont copy replaced text", opts = { silent = true } },
|
["p"] = { 'p:let @+=@0<CR>:let @"=@0<CR>', "Dont copy replaced text", opts = { silent = true } },
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
M.customstuffs = {
|
||||||
|
|
||||||
|
n = {
|
||||||
|
["<Return>"] = { "o<ESC>", "Insert new line below" },
|
||||||
|
["<BS>"] = { "O<ESC>", "Insert new line above" },
|
||||||
|
["<C-c>"] = { "<cmd> vertical topleft Git <bar> vertical resize 50<CR>", "Show Git status on a left pane" },
|
||||||
|
["<F1>"] = { "<cmd> tabprevious<CR>", "Previous tab" },
|
||||||
|
["<F2>"] = { "<cmd> tabnext<CR>", "Next tab" },
|
||||||
|
["<F3>"] = { "<cmd> Flog -all<CR>", "Show git tree" },
|
||||||
|
["<F4>"] = { "<cmd> tab Git show -", "Git show N last commits" },
|
||||||
|
["<C-t>"] = { "<cmd> TagbarToggle<CR>", "Show tagbar" },
|
||||||
|
["<leader>ra"] = { "<cmd> call VrcQuery()<CR>", "Call REST endpoint" },
|
||||||
|
["<leader>dl"] = { "0d$", "Delete line from start" },
|
||||||
|
["<leader>gpu"] = { "<cmd> Git pull<CR>", "Git pull" },
|
||||||
|
["<leader>gpf"] = { ":Git push ", "Git push with option" },
|
||||||
|
["<leader>gmm"] = { "<cmd> Git merge master<CR>", "Git merge master" },
|
||||||
|
["<leader>gmi"] = { ":Git merge ", "Git merge ..." },
|
||||||
|
["<leader>ga"] = { ":Git commit -a --amend --no-edit --no-verify", "Git commit -a --amend --no-edit --no-verify" },
|
||||||
|
["<leader>gnb"] = { ":Git checkout -b ", "Checkout to a new branch" },
|
||||||
|
["<leader>gri"] = { ":Git rebase -i HEAD~", "Git rebase interactive from HEAD" },
|
||||||
|
["<leader>grm"] = { ":Git rebase -i master", "Git rebase interactive from master" },
|
||||||
|
["<leader>grr"] = { ":Git rebase -i ", "Git rebase interactive from <select>" },
|
||||||
|
|
||||||
|
-- ["<leader>mkd"] = { "<cmd>lua vim.api.nvim_create_user_command('PeekOpen', require('peek').open, {})<CR>", "Open markdown preview" },
|
||||||
|
-- ["<leader>mkc"] = { "<cmd>lua vim.api.nvim_create_user_command('PeekClose', require('peek').close, {})<CR>", "Open markdown preview" },
|
||||||
|
|
||||||
|
["n"] = { "nzz", "Next + auto center" },
|
||||||
|
["N"] = { "Nzz", "Previous + auto center" },
|
||||||
|
["("] = { "(zz", "Previous + auto center" },
|
||||||
|
[")"] = { ")zz", "Previous + auto center" },
|
||||||
|
["{"] = { "{zz", "Previous + auto center" },
|
||||||
|
["}"] = { "}zz", "Previous + auto center" },
|
||||||
|
["[["] = { "[[zz", "Previous + auto center" },
|
||||||
|
["]]"] = { "]]zz", "Previous + auto center" },
|
||||||
|
|
||||||
|
-- Mappings: TODO
|
||||||
|
|
||||||
|
-- "trim(system('git branch --show-current 2>/dev/null'))"
|
||||||
|
-- ["<leader>ct"] = { ":call append(line('.') - 1, repeat(' ', indent('.')) . '# TODO-' . trim(system('git branch --show-current 2>/dev/null')) . ': ' . input('Comment >'))<CR>", "Add TODO comment + add to qflist" },
|
||||||
|
["<leader>ct"] = {
|
||||||
|
":call append(line('.') - 1, repeat(' ', indent('.')) . '# TODO: ' . input('Comment >'))<CR>",
|
||||||
|
"Add TODO comment + add to qflist",
|
||||||
|
},
|
||||||
|
|
||||||
|
["<leader>ww"] = { ":lua require('nvim-window').pick()<CR>", "Pick window to goto" },
|
||||||
|
["<leader>wm"] = { ":WinShift<CR>", "Enter move window mode" },
|
||||||
|
["<leader>ws"] = { ":WinShift swap<CR>", "Swap window, with selection" },
|
||||||
|
|
||||||
|
["<leader>gg"] = { ":LazyGit<CR>", "Open lazygit" },
|
||||||
|
|
||||||
|
["gf"] = { ":call search('[A-Z]', 'W')<CR>", "Go to next uppercase" },
|
||||||
|
["fg"] = { ":call search('[A-Z]', 'bW')<CR>", "Go to last uppercase" },
|
||||||
|
|
||||||
|
["glb"] = { ":lua require('gitlab').choose_merge_request()<CR>", "Gitlab: Choose merge request" },
|
||||||
|
["glr"] = { ":lua require('gitlab').review()<CR>", "Gitlab: review" },
|
||||||
|
["gls"] = { ":lua require('gitlab').summary()<CR>", "Gitlab: summary" },
|
||||||
|
["glo"] = { ":lua require('gitlab').open_in_browser()<CR>", "Gitlab: open in browser" },
|
||||||
|
["glu"] = { ":lua require('gitlab').copy_mr_url()<CR>", "Gitlab: open in browser" },
|
||||||
|
["glO"] = { ":lua require('gitlab').create_mr()<CR>", "Gitlab: create MR" },
|
||||||
|
["glaa"] = { ":lua require('gitlab').add_assignee()<CR>", "Gitlab: add_assignee" },
|
||||||
|
|
||||||
|
-- vim.keymap.set("n", "glb", gitlab.choose_merge_request)
|
||||||
|
-- vim.keymap.set("n", "glr", gitlab.review)
|
||||||
|
-- vim.keymap.set("n", "gls", gitlab.summary)
|
||||||
|
-- vim.keymap.set("n", "glA", gitlab.approve)
|
||||||
|
-- vim.keymap.set("n", "glR", gitlab.revoke)
|
||||||
|
-- vim.keymap.set("n", "glc", gitlab.create_comment)
|
||||||
|
-- vim.keymap.set("v", "glc", gitlab.create_multiline_comment)
|
||||||
|
-- vim.keymap.set("v", "glC", gitlab.create_comment_suggestion)
|
||||||
|
-- vim.keymap.set("n", "glO", gitlab.create_mr)
|
||||||
|
-- vim.keymap.set("n", "glm", gitlab.move_to_discussion_tree_from_diagnostic)
|
||||||
|
-- vim.keymap.set("n", "gln", gitlab.create_note)
|
||||||
|
-- vim.keymap.set("n", "gld", gitlab.toggle_discussions)
|
||||||
|
-- vim.keymap.set("n", "glaa", gitlab.add_assignee)
|
||||||
|
-- vim.keymap.set("n", "glad", gitlab.delete_assignee)
|
||||||
|
-- vim.keymap.set("n", "glla", gitlab.add_label)
|
||||||
|
-- vim.keymap.set("n", "glld", gitlab.delete_label)
|
||||||
|
-- vim.keymap.set("n", "glra", gitlab.add_reviewer)
|
||||||
|
-- vim.keymap.set("n", "glrd", gitlab.delete_reviewer)
|
||||||
|
-- vim.keymap.set("n", "glp", gitlab.pipeline)
|
||||||
|
-- vim.keymap.set("n", "glM", gitlab.merge)
|
||||||
|
-- vim.keymap.set("n", "glu", gitlab.copy_mr_url)
|
||||||
|
-- vim.keymap.set("n", "glP", gitlab.publish_all_drafts)
|
||||||
|
},
|
||||||
|
v = {
|
||||||
|
["n"] = { "nzz", "Next + auto center" },
|
||||||
|
["N"] = { "Nzz", "Previous + auto center" },
|
||||||
|
["("] = { "(zz", "Previous + auto center" },
|
||||||
|
[")"] = { ")zz", "Previous + auto center" },
|
||||||
|
["{"] = { "{zz", "Previous + auto center" },
|
||||||
|
["}"] = { "}zz", "Previous + auto center" },
|
||||||
|
["[["] = { "[[zz", "Previous + auto center" },
|
||||||
|
["]]"] = { "]]zz", "Previous + auto center" },
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
M.tabufline = {
|
M.tabufline = {
|
||||||
plugin = true,
|
plugin = true,
|
||||||
|
|
||||||
@ -94,12 +235,12 @@ M.tabufline = {
|
|||||||
},
|
},
|
||||||
|
|
||||||
-- close buffer + hide terminal buffer
|
-- close buffer + hide terminal buffer
|
||||||
["<leader>x"] = {
|
-- ["<leader>x"] = {
|
||||||
function()
|
-- function()
|
||||||
require("nvchad.tabufline").close_buffer()
|
-- require("nvchad.tabufline").close_buffer()
|
||||||
end,
|
-- end,
|
||||||
"Close buffer",
|
-- "Close buffer",
|
||||||
},
|
-- },
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -108,7 +249,7 @@ M.comment = {
|
|||||||
|
|
||||||
-- toggle comment in both modes
|
-- toggle comment in both modes
|
||||||
n = {
|
n = {
|
||||||
["<leader>/"] = {
|
["<leader>ci"] = {
|
||||||
function()
|
function()
|
||||||
require("Comment.api").toggle.linewise.current()
|
require("Comment.api").toggle.linewise.current()
|
||||||
end,
|
end,
|
||||||
@ -117,7 +258,7 @@ M.comment = {
|
|||||||
},
|
},
|
||||||
|
|
||||||
v = {
|
v = {
|
||||||
["<leader>/"] = {
|
["<leader>ci"] = {
|
||||||
"<ESC><cmd>lua require('Comment.api').toggle.linewise(vim.fn.visualmode())<CR>",
|
"<ESC><cmd>lua require('Comment.api').toggle.linewise(vim.fn.visualmode())<CR>",
|
||||||
"Toggle comment",
|
"Toggle comment",
|
||||||
},
|
},
|
||||||
@ -214,18 +355,18 @@ M.lspconfig = {
|
|||||||
"Goto next",
|
"Goto next",
|
||||||
},
|
},
|
||||||
|
|
||||||
["<leader>q"] = {
|
-- ["<leader>q"] = {
|
||||||
function()
|
-- function()
|
||||||
vim.diagnostic.setloclist()
|
-- vim.diagnostic.setloclist()
|
||||||
end,
|
-- end,
|
||||||
"Diagnostic setloclist",
|
-- "Diagnostic setloclist",
|
||||||
},
|
-- },
|
||||||
|
|
||||||
["<leader>wa"] = {
|
["<leader>wa"] = {
|
||||||
function()
|
function()
|
||||||
vim.lsp.buf.add_workspace_folder()
|
vim.lsp.buf.add_workspace_folder()
|
||||||
end,
|
end,
|
||||||
"Add workspace folder",
|
"add workspace folder",
|
||||||
},
|
},
|
||||||
|
|
||||||
["<leader>wr"] = {
|
["<leader>wr"] = {
|
||||||
@ -269,26 +410,145 @@ M.telescope = {
|
|||||||
plugin = true,
|
plugin = true,
|
||||||
|
|
||||||
n = {
|
n = {
|
||||||
|
-- Resume
|
||||||
|
["<a-f>"] = { "<cmd> Telescope resume <CR>", "Resume" },
|
||||||
|
["<a-k>"] = { "<cmd> Telescope keymaps <CR>", "Show (and search) all [k]eymaps" },
|
||||||
-- find
|
-- find
|
||||||
["<leader>ff"] = { "<cmd> Telescope find_files <CR>", "Find files" },
|
["<C-g>"] = { "<cmd> Telescope find_files <CR>", "Find files" },
|
||||||
["<leader>fa"] = { "<cmd> Telescope find_files follow=true no_ignore=true hidden=true <CR>", "Find all" },
|
["<C-x>"] = { "<cmd> Telescope find_files follow=true no_ignore=true hidden=true <CR>", "Find all" },
|
||||||
["<leader>fw"] = { "<cmd> Telescope live_grep <CR>", "Live grep" },
|
["<C-f>"] = { "<cmd> Telescope live_grep <CR>", "Live grep" },
|
||||||
["<leader>fb"] = { "<cmd> Telescope buffers <CR>", "Find buffers" },
|
["<C-b>"] = { "<cmd> Telescope buffers <CR>", "Find buffers" },
|
||||||
|
|
||||||
|
["<leader>ff"] = {
|
||||||
|
"<cmd> lua require('telescope.builtin').live_grep({default_text='<<<<<<< HEAD'}) <CR>",
|
||||||
|
"Search for git conflicts",
|
||||||
|
},
|
||||||
|
|
||||||
|
["<leader>fg<CR>"] = { "<cmd> lua require('telescope.builtin').live_grep({}) <CR>", "Live grep" },
|
||||||
|
["<leader>fg/"] = {
|
||||||
|
"<cmd> lua require('telescope.builtin').live_grep({default_text=vim.fn.getreg('/')}) <CR>",
|
||||||
|
"Live grep with search term",
|
||||||
|
},
|
||||||
|
["<leader>fgw"] = {
|
||||||
|
"<cmd> lua require('telescope.builtin').live_grep({default_text=vim.fn.expand('<cword>')}) <CR>",
|
||||||
|
"Live grep with current word",
|
||||||
|
},
|
||||||
|
|
||||||
|
["<leader>gf<CR>"] = { "<cmd> lua require('telescope.builtin').find_files({}) <CR>", "Find files" },
|
||||||
|
["<leader>gf/"] = {
|
||||||
|
"<cmd> lua require('telescope.builtin').find_files({default_text=vim.fn.getreg('/')}) <CR>",
|
||||||
|
"Find files with search term",
|
||||||
|
},
|
||||||
|
["<leader>gfw"] = {
|
||||||
|
"<cmd> lua require('telescope.builtin').find_files({default_text=vim.fn.expand('<cword>')}) <CR>",
|
||||||
|
"Find files with current word",
|
||||||
|
},
|
||||||
|
|
||||||
|
["<leader>br<CR>"] = {
|
||||||
|
":execute '%s/' . input('Search term >') . '/' . input('Replace by >', '') . '/g | update' <CR>",
|
||||||
|
"Replace pattern in current buffer",
|
||||||
|
},
|
||||||
|
["<leader>br/"] = {
|
||||||
|
":execute '%s/' . input('Search term >', getreg('/')) . '/' . input('Replace by >', '') . '/g | update' <CR>",
|
||||||
|
"Replace search term pattern in current buffer",
|
||||||
|
},
|
||||||
|
["<leader>brw"] = {
|
||||||
|
":execute '%s/' . input('Search term >', expand('<cword>')) . '/' . input('Replace by >', '') . '/g | update' <CR>",
|
||||||
|
"Replace current word pattern in current buffer",
|
||||||
|
},
|
||||||
|
|
||||||
|
-- Quickfix list
|
||||||
|
["<leader>ql"] = { "<cmd> Telescope quickfix <CR>", "Show qflist" },
|
||||||
|
["<leader>qn"] = { ":cnext<CR>", "Jump to next in qflist" },
|
||||||
|
["]q"] = { ":cnext<CR>", "Jump to next in qflist" },
|
||||||
|
["<leader>qp"] = { ":cprevious<CR>", "Jump to previous in qflist" },
|
||||||
|
["[q"] = { ":cprevious<CR>", "Jump to previous in qflist" },
|
||||||
|
["<leader>qc"] = { ":call setqflist([]) | cclose<CR>", "Clear qflist" },
|
||||||
|
|
||||||
|
-- Quickfix replace all
|
||||||
|
["<leader>qr<CR>"] = {
|
||||||
|
":execute 'cfdo' '%s/' . input('Search term >') . '/' . input('Replace by >') . '/gI | update' <CR>",
|
||||||
|
"Replace pattern in all qflist",
|
||||||
|
},
|
||||||
|
["<leader>qr/"] = {
|
||||||
|
":execute 'cfdo' '%s/' . input('Search term >', getreg('/')) . '/' . input('Replace by >') . '/gI | update' <CR>",
|
||||||
|
"Replace search term in all qflist",
|
||||||
|
},
|
||||||
|
["<leader>qrw"] = {
|
||||||
|
":execute 'cfdo' '%s/' . input('Search term >', expand('<cword>')) . '/' . input('Replace by >') . '/gI | update' <CR>",
|
||||||
|
"Replace current word in all qflist",
|
||||||
|
},
|
||||||
|
|
||||||
|
-- Quickfix "search"
|
||||||
|
["<leader>qs<CR>"] = {
|
||||||
|
":execute 'vimgrep' '/' . input('Pattern >') . '\\C/' '**/*' <CR>",
|
||||||
|
"Add <> files in qflist",
|
||||||
|
},
|
||||||
|
["<leader>qs/"] = {
|
||||||
|
":execute 'vimgrep' '/' . input('Pattern >', getreg('/')) . '\\C/' '**/*' <CR>",
|
||||||
|
"Add search term files in qflist",
|
||||||
|
},
|
||||||
|
["<leader>qsw"] = {
|
||||||
|
":execute 'vimgrep' '/' . input('Pattern >', expand('<cword>')) . '\\C/' '**/*' <CR>",
|
||||||
|
"Add current word files in qflist",
|
||||||
|
},
|
||||||
|
|
||||||
|
-- Loclist list
|
||||||
|
["<leader>ll"] = { "<cmd> Telescope loclist <CR>", "Show loclist" },
|
||||||
|
["<leader>ln"] = { ":lnext<CR>", "Jump to next in loclist" },
|
||||||
|
["]l"] = { ":lnext<CR>", "Jump to next in loclist" },
|
||||||
|
["<leader>lp"] = { ":lprevious<CR>", "Jump to previous in loclist" },
|
||||||
|
["[l"] = { ":lprevious<CR>", "Jump to previous in loclist" },
|
||||||
|
["<leader>lc"] = { ":call setloclist([]) | lclose<CR>", "Clear loclist" },
|
||||||
|
|
||||||
["<leader>fh"] = { "<cmd> Telescope help_tags <CR>", "Help page" },
|
["<leader>fh"] = { "<cmd> Telescope help_tags <CR>", "Help page" },
|
||||||
["<leader>fo"] = { "<cmd> Telescope oldfiles <CR>", "Find oldfiles" },
|
["<leader>fo"] = { "<cmd> Telescope oldfiles <CR>", "Find oldfiles" },
|
||||||
["<leader>fz"] = { "<cmd> Telescope current_buffer_fuzzy_find <CR>", "Find in current buffer" },
|
["<leader>fx<CR>"] = { "<cmd> Telescope current_buffer_fuzzy_find <CR>", "Find in current buffer" },
|
||||||
|
["<leader>fx/"] = {
|
||||||
|
"<cmd> lua require('telescope.builtin').current_buffer_fuzzy_find({default_text=vim.fn.getreg('/')}) <CR>",
|
||||||
|
"Fuzzy find in current buffer with actual search",
|
||||||
|
},
|
||||||
|
["<leader>fxw"] = {
|
||||||
|
"<cmd> lua require('telescope.builtin').current_buffer_fuzzy_find({default_text=vim.fn.expand('<cword>')}) <CR>",
|
||||||
|
"Fuzzy find in current buffer with current word",
|
||||||
|
},
|
||||||
|
|
||||||
|
["<leader>wl"] = { "<cmd> Telescope workspaces <CR>", "Find workspaces" },
|
||||||
|
|
||||||
|
["<leader>gm"] = { "<cmd> lua require('custom.telescope').cpickers()<CR>", "Commonly used commands" },
|
||||||
-- git
|
-- git
|
||||||
["<leader>cm"] = { "<cmd> Telescope git_commits <CR>", "Git commits" },
|
--- Commits
|
||||||
["<leader>gt"] = { "<cmd> Telescope git_status <CR>", "Git status" },
|
["<leader>gc"] = { "<cmd> lua require('custom.telescope').my_git_commits()<CR>", "Custom Git commits" },
|
||||||
|
--- Status
|
||||||
|
["<leader>gss"] = { "<cmd> lua require('custom.telescope').my_git_status()<CR>", "Custom Git status" },
|
||||||
|
--- Stash
|
||||||
|
["<leader>gsh"] = { "<cmd> Telescope git_stash<CR>", "Git stash" },
|
||||||
|
--- Branches
|
||||||
|
["<leader>gbb"] = { "<cmd> Telescope git_branches<CR>", "Git branches" },
|
||||||
|
["<leader>gbc"] = { "<cmd> lua require('custom.telescope').my_git_bcommits()<CR>", "Custom Git branchs commits" },
|
||||||
|
|
||||||
-- pick a hidden term
|
-- pick a hidden term
|
||||||
["<leader>pt"] = { "<cmd> Telescope terms <CR>", "Pick hidden term" },
|
["<leader>pt"] = { "<cmd> Telescope terms <CR>", "Pick hidden term" },
|
||||||
|
|
||||||
-- theme switcher
|
-- theme switcher
|
||||||
["<leader>th"] = { "<cmd> Telescope themes <CR>", "Nvchad themes" },
|
-- ["<leader>th"] = { "<cmd> Telescope themes <CR>", "Nvchad themes" },
|
||||||
|
|
||||||
["<leader>ma"] = { "<cmd> Telescope marks <CR>", "telescope bookmarks" },
|
["<leader>ma"] = { "<cmd> Telescope marks <CR>", "telescope bookmarks" },
|
||||||
|
|
||||||
|
-- History
|
||||||
|
["<leader>ch"] = { "<cmd> Telescope command_history <CR>", "telescope commands history" },
|
||||||
|
["<leader>/"] = { "<cmd> Telescope search_history <CR>", "telescope search history" },
|
||||||
|
|
||||||
|
-- Diaglist: LSP diagnostics in quick/loc list
|
||||||
|
["<leader>dw"] = {
|
||||||
|
"<cmd>lua require('diaglist').open_all_diagnostics()<CR>",
|
||||||
|
"Open all open buffers diagnostics in qflist",
|
||||||
|
},
|
||||||
|
["<leader>d0"] = {
|
||||||
|
"<cmd>lua require('diaglist').open_buffer_diagnostics()<CR>",
|
||||||
|
"Open current buffer diagnostics in loclist",
|
||||||
|
},
|
||||||
|
|
||||||
|
["<leader>;"] = { "<cmd> Telescope <CR>", "Open Telescope" },
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -297,21 +557,21 @@ M.nvterm = {
|
|||||||
|
|
||||||
t = {
|
t = {
|
||||||
-- toggle in terminal mode
|
-- toggle in terminal mode
|
||||||
["<A-i>"] = {
|
["<a-i>"] = {
|
||||||
function()
|
function()
|
||||||
require("nvterm.terminal").toggle "float"
|
require("nvterm.terminal").toggle "float"
|
||||||
end,
|
end,
|
||||||
"Toggle floating term",
|
"Toggle floating term",
|
||||||
},
|
},
|
||||||
|
|
||||||
["<A-h>"] = {
|
["<a-h>"] = {
|
||||||
function()
|
function()
|
||||||
require("nvterm.terminal").toggle "horizontal"
|
require("nvterm.terminal").toggle "horizontal"
|
||||||
end,
|
end,
|
||||||
"Toggle horizontal term",
|
"Toggle horizontal term",
|
||||||
},
|
},
|
||||||
|
|
||||||
["<A-v>"] = {
|
["<a-v>"] = {
|
||||||
function()
|
function()
|
||||||
require("nvterm.terminal").toggle "vertical"
|
require("nvterm.terminal").toggle "vertical"
|
||||||
end,
|
end,
|
||||||
@ -321,21 +581,21 @@ M.nvterm = {
|
|||||||
|
|
||||||
n = {
|
n = {
|
||||||
-- toggle in normal mode
|
-- toggle in normal mode
|
||||||
["<A-i>"] = {
|
["<a-i>"] = {
|
||||||
function()
|
function()
|
||||||
require("nvterm.terminal").toggle "float"
|
require("nvterm.terminal").toggle "float"
|
||||||
end,
|
end,
|
||||||
"Toggle floating term",
|
"Toggle floating term",
|
||||||
},
|
},
|
||||||
|
|
||||||
["<A-h>"] = {
|
["<a-h>"] = {
|
||||||
function()
|
function()
|
||||||
require("nvterm.terminal").toggle "horizontal"
|
require("nvterm.terminal").toggle "horizontal"
|
||||||
end,
|
end,
|
||||||
"Toggle horizontal term",
|
"Toggle horizontal term",
|
||||||
},
|
},
|
||||||
|
|
||||||
["<A-v>"] = {
|
["<a-v>"] = {
|
||||||
function()
|
function()
|
||||||
require("nvterm.terminal").toggle "vertical"
|
require("nvterm.terminal").toggle "vertical"
|
||||||
end,
|
end,
|
||||||
@ -434,7 +694,7 @@ M.gitsigns = {
|
|||||||
opts = { expr = true },
|
opts = { expr = true },
|
||||||
},
|
},
|
||||||
|
|
||||||
-- Actions
|
-- actions
|
||||||
["<leader>rh"] = {
|
["<leader>rh"] = {
|
||||||
function()
|
function()
|
||||||
require("gitsigns").reset_hunk()
|
require("gitsigns").reset_hunk()
|
||||||
@ -449,14 +709,14 @@ M.gitsigns = {
|
|||||||
"Preview hunk",
|
"Preview hunk",
|
||||||
},
|
},
|
||||||
|
|
||||||
["<leader>gb"] = {
|
["<leader>bb"] = {
|
||||||
function()
|
function()
|
||||||
package.loaded.gitsigns.blame_line()
|
package.loaded.gitsigns.blame_line()
|
||||||
end,
|
end,
|
||||||
"Blame line",
|
"Blame line",
|
||||||
},
|
},
|
||||||
|
|
||||||
["<leader>td"] = {
|
["<leader>bd"] = {
|
||||||
function()
|
function()
|
||||||
require("gitsigns").toggle_deleted()
|
require("gitsigns").toggle_deleted()
|
||||||
end,
|
end,
|
||||||
@ -465,4 +725,16 @@ M.gitsigns = {
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
local all_modes = {
|
||||||
|
-- Override all delete/yank/paste to use the registers M by default
|
||||||
|
["y"] = { '"my', "Yank", { remap = false } },
|
||||||
|
["p"] = { '"mp', "Paste", { remap = false } },
|
||||||
|
["d"] = { '"md', "Delete", { remap = false } },
|
||||||
|
|
||||||
|
["<leader>y"] = { '"+y', "Yank into system register", { remap = false } },
|
||||||
|
["<leader>p"] = { '"+p', "Paste from system register", { remap = false } },
|
||||||
|
}
|
||||||
|
|
||||||
|
M.general[{ "n", "v" }] = all_modes
|
||||||
|
|
||||||
return M
|
return M
|
||||||
|
|||||||
@ -13,6 +13,9 @@ M.load_config = function()
|
|||||||
config.mappings.disabled = nil
|
config.mappings.disabled = nil
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- print(vim.inspect(config))
|
||||||
|
-- print(config)
|
||||||
|
-- print(vim.inspect(config.ui.statusline))
|
||||||
return config
|
return config
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
56
lua/custom/chadrc.lua
Normal file
56
lua/custom/chadrc.lua
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
---@type ChadrcConfig
|
||||||
|
local M = {}
|
||||||
|
|
||||||
|
-- Path to overriding theme and highlights files
|
||||||
|
local highlights = require "custom.highlights"
|
||||||
|
|
||||||
|
M.ui = {
|
||||||
|
theme = "onedark",
|
||||||
|
theme_toggle = { "onedark", "onedark" },
|
||||||
|
|
||||||
|
hl_override = highlights.override,
|
||||||
|
hl_add = highlights.add,
|
||||||
|
|
||||||
|
statusline = {
|
||||||
|
order = {
|
||||||
|
"macro",
|
||||||
|
"mode",
|
||||||
|
"relativepath",
|
||||||
|
"file",
|
||||||
|
"git",
|
||||||
|
"%=",
|
||||||
|
"lsp_msg",
|
||||||
|
"%=",
|
||||||
|
"diagnostics",
|
||||||
|
"lsp",
|
||||||
|
"cwd",
|
||||||
|
"cursor",
|
||||||
|
},
|
||||||
|
modules = {
|
||||||
|
macro = function()
|
||||||
|
local noice = require "noice"
|
||||||
|
if noice.api.statusline.mode.has() then
|
||||||
|
return "%#St_CommandMode#" .. noice.api.statusline.mode.get()
|
||||||
|
end
|
||||||
|
return ""
|
||||||
|
end,
|
||||||
|
relativepath = function()
|
||||||
|
local stbufnr = vim.api.nvim_win_get_buf(vim.g.statusline_winid or 0)
|
||||||
|
local path = vim.api.nvim_buf_get_name(stbufnr)
|
||||||
|
|
||||||
|
if path == "" then
|
||||||
|
return ""
|
||||||
|
end
|
||||||
|
|
||||||
|
return "%#St_relativepath# " .. vim.fn.expand "%:.:h" .. " /"
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
M.plugins = "custom.plugins"
|
||||||
|
|
||||||
|
-- check core.mappings for table structure
|
||||||
|
M.mappings = require "custom.mappings"
|
||||||
|
|
||||||
|
return M
|
||||||
5
lua/custom/commands.lua
Normal file
5
lua/custom/commands.lua
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
local C = {
|
||||||
|
{ "Replace {{X}} with {{ X }} in jinja template", "%s/{{\\(.[^ ]*\\)}}/{{ \\1 }}/g" },
|
||||||
|
}
|
||||||
|
|
||||||
|
return C
|
||||||
15
lua/custom/configs/lspconfig.lua
Normal file
15
lua/custom/configs/lspconfig.lua
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
local on_attach = require("plugins.configs.lspconfig").on_attach
|
||||||
|
local capabilities = require("plugins.configs.lspconfig").capabilities
|
||||||
|
|
||||||
|
local lspconfig = require "lspconfig"
|
||||||
|
|
||||||
|
-- if you just want default config for the servers then put them in a table
|
||||||
|
-- local servers = { "html", "cssls", "tsserver", "clangd", "salt_ls", "pyright", "jedi_language_server" }
|
||||||
|
local servers = { "html", "cssls", "tsserver", "clangd", "salt_ls" }
|
||||||
|
|
||||||
|
for _, lsp in ipairs(servers) do
|
||||||
|
lspconfig[lsp].setup {
|
||||||
|
on_attach = on_attach,
|
||||||
|
capabilities = capabilities,
|
||||||
|
}
|
||||||
|
end
|
||||||
28
lua/custom/configs/null-ls.lua
Normal file
28
lua/custom/configs/null-ls.lua
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
local present, null_ls = pcall(require, "null-ls")
|
||||||
|
|
||||||
|
if true then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
if not present then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
local b = null_ls.builtins
|
||||||
|
|
||||||
|
local sources = {
|
||||||
|
|
||||||
|
-- webdev stuff
|
||||||
|
b.formatting.deno_fmt, -- choosed deno for ts/js files cuz its very fast!
|
||||||
|
b.formatting.prettier.with { filetypes = { "html", "markdown", "css", "js" }, extra_args = { "--tab-width 4" } }, -- so prettier works only on these filetypes
|
||||||
|
|
||||||
|
-- Lua
|
||||||
|
b.formatting.stylua,
|
||||||
|
|
||||||
|
-- cpp
|
||||||
|
b.formatting.clang_format,
|
||||||
|
}
|
||||||
|
|
||||||
|
null_ls.setup {
|
||||||
|
debug = true,
|
||||||
|
sources = sources,
|
||||||
|
}
|
||||||
68
lua/custom/configs/overrides.lua
Normal file
68
lua/custom/configs/overrides.lua
Normal file
@ -0,0 +1,68 @@
|
|||||||
|
local M = {}
|
||||||
|
|
||||||
|
M.treesitter = {
|
||||||
|
ensure_installed = {
|
||||||
|
"vim",
|
||||||
|
"lua",
|
||||||
|
"html",
|
||||||
|
"css",
|
||||||
|
"javascript",
|
||||||
|
"typescript",
|
||||||
|
"tsx",
|
||||||
|
"c",
|
||||||
|
"markdown",
|
||||||
|
"markdown_inline",
|
||||||
|
},
|
||||||
|
indent = {
|
||||||
|
enable = true,
|
||||||
|
-- disable = {
|
||||||
|
-- "python"
|
||||||
|
-- },
|
||||||
|
},
|
||||||
|
incremental_selection = {
|
||||||
|
enable = true,
|
||||||
|
keymaps = {
|
||||||
|
init_selection = "<C-space>",
|
||||||
|
node_incremental = "<C-space>",
|
||||||
|
scope_incremental = false,
|
||||||
|
node_decremental = "<bs>",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
M.mason = {
|
||||||
|
ensure_installed = {
|
||||||
|
-- lua stuff
|
||||||
|
"lua-language-server",
|
||||||
|
"stylua",
|
||||||
|
|
||||||
|
-- web dev stuff
|
||||||
|
"css-lsp",
|
||||||
|
"html-lsp",
|
||||||
|
"typescript-language-server",
|
||||||
|
"deno",
|
||||||
|
"prettier",
|
||||||
|
|
||||||
|
-- c/cpp stuff
|
||||||
|
"clangd",
|
||||||
|
"clang-format",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
-- git support in nvimtree
|
||||||
|
M.nvimtree = {
|
||||||
|
git = {
|
||||||
|
enable = true,
|
||||||
|
},
|
||||||
|
|
||||||
|
renderer = {
|
||||||
|
highlight_git = true,
|
||||||
|
icons = {
|
||||||
|
show = {
|
||||||
|
git = true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
return M
|
||||||
19
lua/custom/highlights.lua
Normal file
19
lua/custom/highlights.lua
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
-- To find any highlight groups: "<cmd> Telescope highlights"
|
||||||
|
-- Each highlight group can take a table with variables fg, bg, bold, italic, etc
|
||||||
|
-- base30 variable names can also be used as colors
|
||||||
|
|
||||||
|
local M = {}
|
||||||
|
|
||||||
|
---@type Base46HLGroupsList
|
||||||
|
M.override = {
|
||||||
|
Comment = {
|
||||||
|
italic = true,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
---@type HLTable
|
||||||
|
M.add = {
|
||||||
|
NvimTreeOpenedFolderName = { fg = "green", bold = true },
|
||||||
|
}
|
||||||
|
|
||||||
|
return M
|
||||||
7
lua/custom/init.lua
Normal file
7
lua/custom/init.lua
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
-- local autocmd = vim.api.nvim_create_autocmd
|
||||||
|
|
||||||
|
-- Auto resize panes when resizing nvim window
|
||||||
|
-- autocmd("VimResized", {
|
||||||
|
-- pattern = "*",
|
||||||
|
-- command = "tabdo wincmd =",
|
||||||
|
-- })
|
||||||
12
lua/custom/mappings.lua
Normal file
12
lua/custom/mappings.lua
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
---@type MappingsTable
|
||||||
|
local M = {}
|
||||||
|
|
||||||
|
M.general = {
|
||||||
|
n = {
|
||||||
|
[";"] = { ":", "enter command mode", opts = { nowait = true } },
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
-- more keybinds!
|
||||||
|
--
|
||||||
|
return M
|
||||||
65
lua/custom/plugins.lua
Normal file
65
lua/custom/plugins.lua
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
local overrides = require("custom.configs.overrides")
|
||||||
|
|
||||||
|
---@type NvPluginSpec[]
|
||||||
|
local plugins = {
|
||||||
|
|
||||||
|
-- Override plugin definition options
|
||||||
|
|
||||||
|
{
|
||||||
|
"neovim/nvim-lspconfig",
|
||||||
|
dependencies = {
|
||||||
|
-- format & linting
|
||||||
|
{
|
||||||
|
"jose-elias-alvarez/null-ls.nvim",
|
||||||
|
config = function()
|
||||||
|
require "custom.configs.null-ls"
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
config = function()
|
||||||
|
require "plugins.configs.lspconfig"
|
||||||
|
require "custom.configs.lspconfig"
|
||||||
|
end, -- Override to setup mason-lspconfig
|
||||||
|
},
|
||||||
|
|
||||||
|
-- override plugin configs
|
||||||
|
{
|
||||||
|
"williamboman/mason.nvim",
|
||||||
|
opts = overrides.mason
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
"nvim-treesitter/nvim-treesitter",
|
||||||
|
opts = overrides.treesitter,
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
"nvim-tree/nvim-tree.lua",
|
||||||
|
opts = overrides.nvimtree,
|
||||||
|
},
|
||||||
|
|
||||||
|
-- Install a plugin
|
||||||
|
{
|
||||||
|
"max397574/better-escape.nvim",
|
||||||
|
event = "InsertEnter",
|
||||||
|
config = function()
|
||||||
|
require("better_escape").setup()
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
|
||||||
|
-- To make a plugin not be loaded
|
||||||
|
-- {
|
||||||
|
-- "NvChad/nvim-colorizer.lua",
|
||||||
|
-- enabled = false
|
||||||
|
-- },
|
||||||
|
|
||||||
|
-- All NvChad plugins are lazy-loaded by default
|
||||||
|
-- For a plugin to be loaded, you will need to set either `ft`, `cmd`, `keys`, `event`, or set `lazy = false`
|
||||||
|
-- If you want a plugin to load on startup, add `lazy = false` to a plugin spec, for example
|
||||||
|
-- {
|
||||||
|
-- "mg979/vim-visual-multi",
|
||||||
|
-- lazy = false,
|
||||||
|
-- }
|
||||||
|
}
|
||||||
|
|
||||||
|
return plugins
|
||||||
107
lua/custom/telescope.lua
Normal file
107
lua/custom/telescope.lua
Normal file
@ -0,0 +1,107 @@
|
|||||||
|
-- Implement delta as previewer for diffs
|
||||||
|
|
||||||
|
local previewers = require('telescope.previewers')
|
||||||
|
local builtin = require('telescope.builtin')
|
||||||
|
local pickers = require("telescope.pickers")
|
||||||
|
local finders = require("telescope.finders")
|
||||||
|
local actions = require("telescope.actions")
|
||||||
|
local action_state = require("telescope.actions.state")
|
||||||
|
local conf = require("telescope.config").values
|
||||||
|
|
||||||
|
local E = {}
|
||||||
|
|
||||||
|
local delta = previewers.new_termopen_previewer {
|
||||||
|
get_command = function(entry)
|
||||||
|
-- this is for status
|
||||||
|
-- You can get the AM things in entry.status. So we are displaying file if entry.status == '??' or 'A '
|
||||||
|
-- just do an if and return a different command
|
||||||
|
if entry.status == '??' or 'A ' then
|
||||||
|
return { 'git', '-c', 'core.pager=delta', '-c', 'delta.side-by-side=false', 'diff', entry.value }
|
||||||
|
end
|
||||||
|
|
||||||
|
-- note we can't use pipes
|
||||||
|
-- this command is for git_commits and git_bcommits
|
||||||
|
return { 'git', '-c', 'core.pager=delta', '-c', 'delta.side-by-side=false', 'diff', entry.value .. '^!' }
|
||||||
|
|
||||||
|
end
|
||||||
|
}
|
||||||
|
|
||||||
|
E.my_git_commits = function(opts)
|
||||||
|
opts = opts or {}
|
||||||
|
opts.previewer = delta
|
||||||
|
|
||||||
|
builtin.git_commits(opts)
|
||||||
|
end
|
||||||
|
|
||||||
|
E.my_git_bcommits = function(opts)
|
||||||
|
opts = opts or {}
|
||||||
|
opts.previewer = delta
|
||||||
|
|
||||||
|
builtin.git_bcommits(opts)
|
||||||
|
end
|
||||||
|
|
||||||
|
E.my_git_status = function(opts)
|
||||||
|
opts = opts or {}
|
||||||
|
opts.previewer = delta
|
||||||
|
|
||||||
|
builtin.git_status(opts)
|
||||||
|
end
|
||||||
|
|
||||||
|
E.my_git_branches = function(opts)
|
||||||
|
opts = opts or {}
|
||||||
|
opts.previewer = delta
|
||||||
|
|
||||||
|
builtin.git_branches(opts)
|
||||||
|
end
|
||||||
|
|
||||||
|
E.project_files = function()
|
||||||
|
local opts = {} -- define here if you want to define something
|
||||||
|
vim.fn.system('git rev-parse --is-inside-work-tree')
|
||||||
|
if vim.v.shell_error == 0 then
|
||||||
|
require"telescope.builtin".git_files(opts)
|
||||||
|
else
|
||||||
|
require"telescope.builtin".find_files(opts)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local custom_commands = require("custom.commands")
|
||||||
|
|
||||||
|
E.cpickers = function(opts)
|
||||||
|
opts = opts or {}
|
||||||
|
pickers.new(opts, {
|
||||||
|
prompt_title = "Commands",
|
||||||
|
|
||||||
|
finder = finders.new_table {
|
||||||
|
results = custom_commands,
|
||||||
|
entry_maker = function(entry)
|
||||||
|
return {
|
||||||
|
value = entry,
|
||||||
|
display = entry[1],
|
||||||
|
ordinal = entry[2],
|
||||||
|
}
|
||||||
|
end
|
||||||
|
},
|
||||||
|
|
||||||
|
previewer = previewers.new_buffer_previewer {
|
||||||
|
title = "Custom commands preview",
|
||||||
|
define_preview = function (self, entry, _)
|
||||||
|
vim.api.nvim_buf_set_lines(self.state.bufnr, 0, -1, false, {
|
||||||
|
entry['ordinal'],
|
||||||
|
})
|
||||||
|
end
|
||||||
|
},
|
||||||
|
|
||||||
|
attach_mappings = function(prompt_bufnr, _)
|
||||||
|
actions.select_default:replace(function()
|
||||||
|
actions.close(prompt_bufnr)
|
||||||
|
local selection = action_state.get_selected_entry()
|
||||||
|
vim.cmd(selection.ordinal)
|
||||||
|
end)
|
||||||
|
return true
|
||||||
|
end,
|
||||||
|
|
||||||
|
sorter = conf.generic_sorter(opts),
|
||||||
|
}):find()
|
||||||
|
end
|
||||||
|
|
||||||
|
return E
|
||||||
5
lua/plugins/configs/diffview.lua
Normal file
5
lua/plugins/configs/diffview.lua
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
local actions = require("diffview.actions")
|
||||||
|
|
||||||
|
local options = {}
|
||||||
|
|
||||||
|
return options
|
||||||
138
lua/plugins/configs/gitlab.lua
Normal file
138
lua/plugins/configs/gitlab.lua
Normal file
@ -0,0 +1,138 @@
|
|||||||
|
local M = {
|
||||||
|
port = nil, -- The port of the Go server, which runs in the background, if omitted or `nil` the port will be chosen automatically
|
||||||
|
log_path = vim.fn.stdpath("cache") .. "/gitlab.nvim.log", -- Log path for the Go server
|
||||||
|
config_path = nil, -- Custom path for `.gitlab.nvim` file, please read the "Connecting to Gitlab" section
|
||||||
|
debug = {
|
||||||
|
go_request = false,
|
||||||
|
go_response = false,
|
||||||
|
},
|
||||||
|
attachment_dir = nil, -- The local directory for files (see the "summary" section)
|
||||||
|
reviewer_settings = {
|
||||||
|
diffview = {
|
||||||
|
imply_local = false, -- If true, will attempt to use --imply_local option when calling |:DiffviewOpen|
|
||||||
|
},
|
||||||
|
},
|
||||||
|
connection_settings = {
|
||||||
|
insecure = false, -- Like curl's --insecure option, ignore bad x509 certificates on connection
|
||||||
|
},
|
||||||
|
help = "g?", -- Opens a help popup for local keymaps when a relevant view is focused (popup, discussion panel, etc)
|
||||||
|
popup = { -- The popup for comment creation, editing, and replying
|
||||||
|
keymaps = {
|
||||||
|
next_field = "<Tab>", -- Cycle to the next field. Accepts count.
|
||||||
|
prev_field = "<S-Tab>", -- Cycle to the previous field. Accepts count.
|
||||||
|
},
|
||||||
|
perform_action = "<leader>s", -- Once in normal mode, does action (like saving comment or editing description, etc)
|
||||||
|
perform_linewise_action = "<leader>l", -- Once in normal mode, does the linewise action (see logs for this job, etc)
|
||||||
|
width = "50%",
|
||||||
|
height = "80%",
|
||||||
|
border = "rounded", -- One of "
|
||||||
|
opacity = 1.0, -- From 0.0 (fully transparent) to 1.0 (fully opaque)
|
||||||
|
comment = nil, -- Individual popup overrides, e.g. { width = "60%", height = "80%", border = "single", opacity = 0.85 },
|
||||||
|
edit = nil,
|
||||||
|
note = nil,
|
||||||
|
pipeline = nil,
|
||||||
|
reply = nil,
|
||||||
|
squash_message = nil,
|
||||||
|
temp_registers = {}, -- List of registers for backing up popup content (see `:h gitlab.nvim.temp-registers`)
|
||||||
|
},
|
||||||
|
discussion_tree = { -- The discussion tree that holds all comments
|
||||||
|
auto_open = true, -- Automatically open when the reviewer is opened
|
||||||
|
switch_view = "S", -- Toggles between the notes and discussions views
|
||||||
|
default_view = "discussions", -- Show "discussions" or "notes" by default
|
||||||
|
blacklist = {}, -- List of usernames to remove from tree (bots, CI, etc)
|
||||||
|
jump_to_file = "o", -- Jump to comment location in file
|
||||||
|
jump_to_reviewer = "m", -- Jump to the location in the reviewer window
|
||||||
|
edit_comment = "e", -- Edit comment
|
||||||
|
delete_comment = "dd", -- Delete comment
|
||||||
|
reply = "r", -- Reply to comment
|
||||||
|
toggle_node = "t", -- Opens or closes the discussion
|
||||||
|
add_emoji = "Ea", -- Add an emoji to the note/comment
|
||||||
|
-- add_emoji = "Ed", -- Remove an emoji from a note/comment
|
||||||
|
toggle_all_discussions = "T", -- Open or close separately both resolved and unresolved discussions
|
||||||
|
toggle_resolved_discussions = "R", -- Open or close all resolved discussions
|
||||||
|
toggle_unresolved_discussions = "U", -- Open or close all unresolved discussions
|
||||||
|
keep_current_open = false, -- If true, current discussion stays open even if it should otherwise be closed when toggling
|
||||||
|
publish_draft = "P", -- Publishes the currently focused note/comment
|
||||||
|
toggle_resolved = "p", -- Toggles the resolved status of the whole discussion
|
||||||
|
position = "left", -- "top", "right", "bottom" or "left"
|
||||||
|
open_in_browser = "b", -- Jump to the URL of the current note/discussion
|
||||||
|
copy_node_url = "u", -- Copy the URL of the current node to clipboard
|
||||||
|
size = "30%", -- Size of split
|
||||||
|
relative = "editor", -- Position of tree split relative to "editor" or "window"
|
||||||
|
resolved = '✓', -- Symbol to show next to resolved discussions
|
||||||
|
unresolved = '✗', -- Symbol to show next to unresolved discussions
|
||||||
|
tree_type = "by_file_name", -- Type of discussion tree - "simple" means just list of discussions, "by_file_name" means file tree with discussions under file
|
||||||
|
toggle_tree_type = "i", -- Toggle type of discussion tree - "simple", or "by_file_name"
|
||||||
|
draft_mode = false, -- Whether comments are posted as drafts as part of a review
|
||||||
|
toggle_draft_mode = "D", -- Toggle between draft mode (comments posted as drafts) and live mode (comments are posted immediately)
|
||||||
|
winbar = nil, -- Custom function to return winbar title, should return a string. Provided with WinbarTable (defined in annotations.lua)
|
||||||
|
-- If using lualine, please add "gitlab" to disabled file types, otherwise you will not see the winbar.
|
||||||
|
},
|
||||||
|
choose_merge_request = {
|
||||||
|
open_reviewer = true, -- Open the reviewer window automatically after switching merge requests
|
||||||
|
},
|
||||||
|
info = { -- Show additional fields in the summary view
|
||||||
|
enabled = true,
|
||||||
|
horizontal = false, -- Display metadata to the left of the summary rather than underneath
|
||||||
|
fields = { -- The fields listed here will be displayed, in whatever order you choose
|
||||||
|
"author",
|
||||||
|
"created_at",
|
||||||
|
"updated_at",
|
||||||
|
"merge_status",
|
||||||
|
"draft",
|
||||||
|
"conflicts",
|
||||||
|
"assignees",
|
||||||
|
"reviewers",
|
||||||
|
"pipeline",
|
||||||
|
"branch",
|
||||||
|
"target_branch",
|
||||||
|
"delete_branch",
|
||||||
|
"squash",
|
||||||
|
"labels",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
discussion_signs = {
|
||||||
|
enabled = true, -- Show diagnostics for gitlab comments in the reviewer
|
||||||
|
skip_resolved_discussion = false, -- Show diagnostics for resolved discussions
|
||||||
|
severity = vim.diagnostic.severity.INFO, -- ERROR, WARN, INFO, or HINT
|
||||||
|
virtual_text = false, -- Whether to show the comment text inline as floating virtual text
|
||||||
|
priority = 100, -- Higher will override LSP warnings, etc
|
||||||
|
icons = {
|
||||||
|
comment = "→|",
|
||||||
|
range = " |",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
pipeline = {
|
||||||
|
created = "",
|
||||||
|
pending = "",
|
||||||
|
preparing = "",
|
||||||
|
scheduled = "",
|
||||||
|
running = "",
|
||||||
|
canceled = "↪",
|
||||||
|
skipped = "↪",
|
||||||
|
success = "✓",
|
||||||
|
failed = "",
|
||||||
|
},
|
||||||
|
create_mr = {
|
||||||
|
target = "master", -- Default branch to target when creating an MR
|
||||||
|
template_file = nil, -- Default MR template in .gitlab/merge_request_templates
|
||||||
|
delete_branch = false, -- Whether the source branch will be marked for deletion
|
||||||
|
squash = false, -- Whether the commits will be marked for squashing
|
||||||
|
title_input = { -- Default settings for MR title input window
|
||||||
|
width = 40,
|
||||||
|
border = "rounded",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
colors = {
|
||||||
|
discussion_tree = {
|
||||||
|
username = "Keyword",
|
||||||
|
date = "Comment",
|
||||||
|
chevron = "DiffviewNonText",
|
||||||
|
directory = "Directory",
|
||||||
|
directory_icon = "DiffviewFolderSign",
|
||||||
|
file_name = "Normal",
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return M
|
||||||
35
lua/plugins/configs/hydra.lua
Normal file
35
lua/plugins/configs/hydra.lua
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
local Hydra = require("hydra")
|
||||||
|
|
||||||
|
Hydra({
|
||||||
|
name = "Change / Resize Window",
|
||||||
|
mode = { "n" },
|
||||||
|
body = "<leader>t",
|
||||||
|
config = {
|
||||||
|
-- color = "pink",
|
||||||
|
},
|
||||||
|
heads = {
|
||||||
|
-- move between windows
|
||||||
|
{ "<C-h>", "<C-w>h", { desc="Noot nooty" } },
|
||||||
|
{ "<C-j>", "<C-w>j" },
|
||||||
|
{ "<C-k>", "<C-w>k" },
|
||||||
|
{ "<C-l>", "<C-w>l" },
|
||||||
|
|
||||||
|
-- resizing window
|
||||||
|
{ "H", "<C-w>3<" },
|
||||||
|
{ "L", "<C-w>3>" },
|
||||||
|
{ "K", "<C-w>2+" },
|
||||||
|
{ "J", "<C-w>2-" },
|
||||||
|
|
||||||
|
-- equalize window sizes
|
||||||
|
{ "e", "<C-w>=" },
|
||||||
|
|
||||||
|
-- close active window
|
||||||
|
{ "Q", ":q<cr>" },
|
||||||
|
{ "<C-q>", ":q<cr>" },
|
||||||
|
|
||||||
|
-- exit this Hydra
|
||||||
|
{ "q", nil, { exit = true, nowait = true } },
|
||||||
|
{ ";", nil, { exit = true, nowait = true } },
|
||||||
|
{ "<Esc>", nil, { exit = true, nowait = true } },
|
||||||
|
},
|
||||||
|
})
|
||||||
@ -5,17 +5,16 @@ local M = {}
|
|||||||
local utils = require "core.utils"
|
local utils = require "core.utils"
|
||||||
|
|
||||||
-- export on_attach & capabilities for custom lspconfigs
|
-- export on_attach & capabilities for custom lspconfigs
|
||||||
|
|
||||||
M.on_attach = function(client, bufnr)
|
M.on_attach = function(client, bufnr)
|
||||||
client.server_capabilities.documentFormattingProvider = false
|
|
||||||
client.server_capabilities.documentRangeFormattingProvider = false
|
|
||||||
|
|
||||||
utils.load_mappings("lspconfig", { buffer = bufnr })
|
utils.load_mappings("lspconfig", { buffer = bufnr })
|
||||||
|
|
||||||
if client.server_capabilities.signatureHelpProvider then
|
if client.server_capabilities.signatureHelpProvider then
|
||||||
require("nvchad.signature").setup(client)
|
require("nvchad.signature").setup(client)
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- disable semantic tokens
|
||||||
|
M.on_init = function(client, _)
|
||||||
if not utils.load_config().ui.lsp_semantic_tokens and client.supports_method "textDocument/semanticTokens" then
|
if not utils.load_config().ui.lsp_semantic_tokens and client.supports_method "textDocument/semanticTokens" then
|
||||||
client.server_capabilities.semanticTokensProvider = nil
|
client.server_capabilities.semanticTokensProvider = nil
|
||||||
end
|
end
|
||||||
@ -41,9 +40,19 @@ M.capabilities.textDocument.completion.completionItem = {
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
M.capabilities.textDocument.publishDiagnostics.tagSupport.valueSet = { 2 }
|
||||||
|
|
||||||
|
-- LSP settings (for overriding per client)
|
||||||
|
M.handlers = {
|
||||||
|
["textDocument/hover"] = vim.lsp.with(vim.lsp.handlers.hover, { border = "rounded" }),
|
||||||
|
["textDocument/signatureHelp"] = vim.lsp.with(vim.lsp.handlers.signature_help, { border = "rounded" }),
|
||||||
|
}
|
||||||
|
|
||||||
require("lspconfig").lua_ls.setup {
|
require("lspconfig").lua_ls.setup {
|
||||||
|
on_init = M.on_init,
|
||||||
on_attach = M.on_attach,
|
on_attach = M.on_attach,
|
||||||
capabilities = M.capabilities,
|
capabilities = M.capabilities,
|
||||||
|
handlers = M.handlers,
|
||||||
|
|
||||||
settings = {
|
settings = {
|
||||||
Lua = {
|
Lua = {
|
||||||
@ -64,4 +73,82 @@ require("lspconfig").lua_ls.setup {
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
-- local capabilities = vim.lsp.protocol.make_client_capabilities()
|
||||||
|
-- capabilities.textDocument.publishDiagnostics.tagSupport.valueSet = { 2 }
|
||||||
|
|
||||||
|
require("lspconfig").pyright.setup {
|
||||||
|
on_init = M.on_init,
|
||||||
|
on_attach = M.on_attach,
|
||||||
|
capabilities = M.capabilities,
|
||||||
|
handlers = M.handlers,
|
||||||
|
|
||||||
|
settings = {
|
||||||
|
pyright = {
|
||||||
|
-- Options available here: https://github.com/microsoft/pyright/blob/main/docs/settings.md
|
||||||
|
disableOrganizeImports = true, -- Using Ruff
|
||||||
|
-- disableLanguageServices = true, -- Using Ruff
|
||||||
|
},
|
||||||
|
python = {
|
||||||
|
analysis = {
|
||||||
|
-- ignore = { "*" }, -- Using Ruff
|
||||||
|
-- typeCheckingMode = "off", -- Using mypy
|
||||||
|
diagnosticSeverityOverrides = {
|
||||||
|
reportMissingImports = false,
|
||||||
|
reportAttributeAccessIssue = false,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
-- -- This can be used for removing message based on regex etc. For now, all those message are disabled by the tagSupport.valueSet
|
||||||
|
-- local function filter(arr, func)
|
||||||
|
-- -- Filter in place
|
||||||
|
-- -- https://stackoverflow.com/questions/49709998/how-to-filter-a-lua-array-inplace
|
||||||
|
-- local new_index = 1
|
||||||
|
-- local size_orig = #arr
|
||||||
|
-- for old_index, v in ipairs(arr) do
|
||||||
|
-- if func(v, old_index) then
|
||||||
|
-- arr[new_index] = v
|
||||||
|
-- new_index = new_index + 1
|
||||||
|
-- end
|
||||||
|
-- end
|
||||||
|
-- for i = new_index, size_orig do
|
||||||
|
-- arr[i] = nil
|
||||||
|
-- end
|
||||||
|
-- end
|
||||||
|
--
|
||||||
|
-- local function filter_diagnostics(diagnostic)
|
||||||
|
-- -- Only filter out Pyright stuff for now
|
||||||
|
-- if diagnostic.source ~= "Pyright" then
|
||||||
|
-- return true
|
||||||
|
-- end
|
||||||
|
--
|
||||||
|
-- -- Allow kwargs to be unused, sometimes you want many functions to take the
|
||||||
|
-- -- same arguments but you don't use all the arguments in all the functions,
|
||||||
|
-- -- so kwargs is used to suck up all the extras
|
||||||
|
-- if diagnostic.message == '"kwargs" is not accessed' then
|
||||||
|
-- return false
|
||||||
|
-- end
|
||||||
|
--
|
||||||
|
-- -- Allow variables starting with an underscore
|
||||||
|
-- if string.match(diagnostic.message, '"_.+" is not accessed') then
|
||||||
|
-- return false
|
||||||
|
-- end
|
||||||
|
--
|
||||||
|
-- -- For now, remove all not accessed message. I will still have assigned but not accessed message!
|
||||||
|
-- if string.match(diagnostic.message, '".+" is not accessed') then
|
||||||
|
-- return false
|
||||||
|
-- end
|
||||||
|
--
|
||||||
|
-- return true
|
||||||
|
-- end
|
||||||
|
--
|
||||||
|
-- local function custom_on_publish_diagnostics(a, params, client_id, c)
|
||||||
|
-- filter(params.diagnostics, filter_diagnostics)
|
||||||
|
-- vim.lsp.diagnostic.on_publish_diagnostics(a, params, client_id, c)
|
||||||
|
-- end
|
||||||
|
--
|
||||||
|
-- vim.lsp.handlers["textDocument/publishDiagnostics"] = vim.lsp.with(custom_on_publish_diagnostics, {})
|
||||||
|
|
||||||
return M
|
return M
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
local options = {
|
local options = {
|
||||||
ensure_installed = { "lua-language-server" }, -- not an option from mason.nvim
|
ensure_installed = { "lua-language-server" }, -- not an option from mason.nvim
|
||||||
|
|
||||||
PATH = "skip",
|
PATH = "prepand",
|
||||||
|
|
||||||
ui = {
|
ui = {
|
||||||
icons = {
|
icons = {
|
||||||
|
|||||||
46
lua/plugins/configs/noice.lua
Normal file
46
lua/plugins/configs/noice.lua
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
local M = {
|
||||||
|
lsp = {
|
||||||
|
-- override markdown rendering so that **cmp** and other plugins use **Treesitter**
|
||||||
|
override = {
|
||||||
|
["vim.lsp.util.convert_input_to_markdown_lines"] = true,
|
||||||
|
["vim.lsp.util.stylize_markdown"] = true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
-- you can enable a preset for easier configuration
|
||||||
|
presets = {
|
||||||
|
bottom_search = true, -- use a classic bottom cmdline for search
|
||||||
|
command_palette = true, -- position the cmdline and popupmenu together
|
||||||
|
long_message_to_split = true, -- long messages will be sent to a split
|
||||||
|
inc_rename = false, -- enables an input dialog for inc-rename.nvim
|
||||||
|
lsp_doc_border = false, -- add a border to hover docs and signature help
|
||||||
|
},
|
||||||
|
views = {
|
||||||
|
cmdline_popup = {
|
||||||
|
-- border = {
|
||||||
|
-- style = "none",
|
||||||
|
-- padding = { 2, 3 },
|
||||||
|
-- },
|
||||||
|
-- position = {
|
||||||
|
-- row = "85%",
|
||||||
|
-- col = "50%",
|
||||||
|
-- },
|
||||||
|
size = {
|
||||||
|
width = 120,
|
||||||
|
height = "auto",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
popupmenu = {
|
||||||
|
-- relative = "editor",
|
||||||
|
-- position = {
|
||||||
|
-- row = 25,
|
||||||
|
-- col = "50%",
|
||||||
|
-- },
|
||||||
|
size = {
|
||||||
|
width = 120,
|
||||||
|
-- height = 10,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
return M
|
||||||
48
lua/plugins/configs/ruff_lsp.lua
Normal file
48
lua/plugins/configs/ruff_lsp.lua
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
-- See: https://github.com/neovim/nvim-lspconfig/tree/54eb2a070a4f389b1be0f98070f81d23e2b1a715#suggested-configuration
|
||||||
|
local opts = { noremap = true, silent = true }
|
||||||
|
vim.keymap.set("n", "<space>k", vim.diagnostic.open_float, opts)
|
||||||
|
vim.keymap.set("n", "[d", vim.diagnostic.goto_prev, opts)
|
||||||
|
vim.keymap.set("n", "]d", vim.diagnostic.goto_next, opts)
|
||||||
|
-- vim.keymap.set('n', '<space>q', vim.diagnostic.setloclist, opts)
|
||||||
|
|
||||||
|
-- Use an on_attach function to only map the following keys
|
||||||
|
-- after the language server attaches to the current buffer
|
||||||
|
local on_attach = function(client, bufnr)
|
||||||
|
-- Enable completion triggered by <c-x><c-o>
|
||||||
|
vim.api.nvim_buf_set_option(bufnr, "omnifunc", "v:lua.vim.lsp.omnifunc")
|
||||||
|
|
||||||
|
-- Mappings.
|
||||||
|
-- See `:help vim.lsp.*` for documentation on any of the below functions
|
||||||
|
local bufopts = { noremap = true, silent = true, buffer = bufnr }
|
||||||
|
-- vim.keymap.set("n", "gD", vim.lsp.buf.declaration, bufopts)
|
||||||
|
-- vim.keymap.set("n", "gd", vim.lsp.buf.definition, bufopts)
|
||||||
|
-- vim.keymap.set("n", "K", vim.lsp.buf.hover, bufopts)
|
||||||
|
-- vim.keymap.set("n", "gi", vim.lsp.buf.implementation, bufopts)
|
||||||
|
-- vim.keymap.set('n', '<C-k>', vim.lsp.buf.signature_help, bufopts)
|
||||||
|
-- vim.keymap.set("n", "<space>wa", vim.lsp.buf.add_workspace_folder, bufopts)
|
||||||
|
-- vim.keymap.set("n", "<space>wr", vim.lsp.buf.remove_workspace_folder, bufopts)
|
||||||
|
-- vim.keymap.set("n", "<space>wl", function()
|
||||||
|
-- print(vim.inspect(vim.lsp.buf.list_workspace_folders()))
|
||||||
|
-- end, bufopts)
|
||||||
|
|
||||||
|
-- vim.keymap.set("n", "<space>D", vim.lsp.buf.type_definition, bufopts)
|
||||||
|
-- vim.keymap.set("n", "<space>rn", vim.lsp.buf.rename, bufopts)
|
||||||
|
vim.keymap.set("n", "<space>ca", vim.lsp.buf.code_action, bufopts)
|
||||||
|
-- vim.keymap.set("n", "gr", vim.lsp.buf.references, bufopts)
|
||||||
|
-- vim.keymap.set("n", "<space>f", function()
|
||||||
|
-- vim.lsp.buf.format { async = true }
|
||||||
|
-- end, bufopts)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Configure `ruff-lsp`.
|
||||||
|
-- See: https://github.com/neovim/nvim-lspconfig/blob/master/doc/server_configurations.md#ruff_lsp
|
||||||
|
-- For the default config, along with instructions on how to customize the settings
|
||||||
|
require("lspconfig").ruff_lsp.setup {
|
||||||
|
on_attach = on_attach,
|
||||||
|
init_options = {
|
||||||
|
settings = {
|
||||||
|
-- Any extra CLI arguments for `ruff` go here.
|
||||||
|
args = { "--ignore", "E741" },
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
@ -1,3 +1,225 @@
|
|||||||
|
local custom_actions = {}
|
||||||
|
local actions = require("telescope.actions")
|
||||||
|
local lga_actions = require("telescope-live-grep-args.actions")
|
||||||
|
local action_state = require("telescope.actions.state")
|
||||||
|
local from_entry = require("telescope.from_entry")
|
||||||
|
local scan = require("plenary.scandir")
|
||||||
|
local pickers = require("telescope.pickers")
|
||||||
|
local finders = require("telescope.finders")
|
||||||
|
local make_entry = require("telescope.make_entry")
|
||||||
|
local action_set = require 'telescope.actions.set'
|
||||||
|
local conf = require('telescope.config').values
|
||||||
|
local builtin = require("telescope.builtin")
|
||||||
|
|
||||||
|
-- Usefull:
|
||||||
|
-- [[
|
||||||
|
-- https://github.com/JoosepAlviste/dotfiles/blob/master/config/nvim/lua/j/telescope_custom_pickers.lua
|
||||||
|
-- ]]
|
||||||
|
|
||||||
|
|
||||||
|
local entry_to_qf = function(entry)
|
||||||
|
local text = entry.text
|
||||||
|
|
||||||
|
if not text then
|
||||||
|
if type(entry.value) == "table" then
|
||||||
|
text = entry.value.text
|
||||||
|
else
|
||||||
|
text = entry.value
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return {
|
||||||
|
bufnr = entry.bufnr,
|
||||||
|
filename = from_entry.path(entry, false, false),
|
||||||
|
lnum = vim.F.if_nil(entry.lnum, 1),
|
||||||
|
col = vim.F.if_nil(entry.col, 1),
|
||||||
|
text = text,
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
local send_selected_to_list_without_closing_prompt = function(prompt_bufnr, mode, target)
|
||||||
|
local picker = action_state.get_current_picker(prompt_bufnr)
|
||||||
|
|
||||||
|
local qf_entries = {}
|
||||||
|
for _, entry in ipairs(picker:get_multi_selection()) do
|
||||||
|
table.insert(qf_entries, entry_to_qf(entry))
|
||||||
|
end
|
||||||
|
|
||||||
|
local prompt = picker:_get_prompt()
|
||||||
|
-- actions.close(prompt_bufnr)
|
||||||
|
|
||||||
|
vim.api.nvim_exec_autocmds("QuickFixCmdPre", {})
|
||||||
|
if target == "loclist" then
|
||||||
|
vim.fn.setloclist(picker.original_win_id, qf_entries, mode)
|
||||||
|
else
|
||||||
|
local qf_title = string.format([[%s (%s)]], picker.prompt_title, prompt)
|
||||||
|
vim.fn.setqflist(qf_entries, mode)
|
||||||
|
vim.fn.setqflist({}, "a", { title = qf_title })
|
||||||
|
end
|
||||||
|
vim.api.nvim_exec_autocmds("QuickFixCmdPost", {})
|
||||||
|
end
|
||||||
|
|
||||||
|
function custom_actions._multiopen(prompt_bufnr, cmd, cmd2, mode, list)
|
||||||
|
-- actions.send_selected_to_loclist(prompt_bufnr)
|
||||||
|
local picker = action_state.get_current_picker(prompt_bufnr)
|
||||||
|
local multi = picker:get_multi_selection()
|
||||||
|
local single = picker:get_selection()
|
||||||
|
|
||||||
|
local str = ""
|
||||||
|
|
||||||
|
if #multi > 0 then
|
||||||
|
|
||||||
|
send_selected_to_list_without_closing_prompt(prompt_bufnr, mode, list)
|
||||||
|
|
||||||
|
for i, j in ipairs(multi) do
|
||||||
|
if i % 2 == 1 then
|
||||||
|
str = str..cmd.." "..j[1].." | "
|
||||||
|
else
|
||||||
|
str = str..cmd2.." "..j[1].." | "
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
else
|
||||||
|
str = cmd.." "..single[1]
|
||||||
|
end
|
||||||
|
|
||||||
|
-- To avoid populating qf or doing ":edit! file", close the prompt first
|
||||||
|
actions.close(prompt_bufnr)
|
||||||
|
vim.api.nvim_command(str)
|
||||||
|
end
|
||||||
|
|
||||||
|
function custom_actions.multi_selection_open(prompt_bufnr)
|
||||||
|
return custom_actions._multiopen(prompt_bufnr, "edit", "edit", "a", "loclist")
|
||||||
|
end
|
||||||
|
|
||||||
|
function custom_actions.multi_selection_vsplit(prompt_bufnr)
|
||||||
|
return custom_actions._multiopen(prompt_bufnr, "vsplit", "split", "a", "loclist")
|
||||||
|
end
|
||||||
|
|
||||||
|
function custom_actions.multi_selection_split(prompt_bufnr)
|
||||||
|
return custom_actions._multiopen(prompt_bufnr, "split", "vsplit", "a", "loclist")
|
||||||
|
end
|
||||||
|
|
||||||
|
function custom_actions.multi_selection_vtab(prompt_bufnr)
|
||||||
|
return custom_actions._multiopen(prompt_bufnr, "tabe", "tabe", "a", "loclist")
|
||||||
|
end
|
||||||
|
|
||||||
|
function custom_actions.set_extension(prompt_bufnr)
|
||||||
|
local current_input = action_state.get_current_line()
|
||||||
|
|
||||||
|
vim.ui.input({ prompt = 'Search in extension: *.' }, function(input)
|
||||||
|
if input == nil then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Close and reopen a prompt with the same input
|
||||||
|
actions.close(prompt_bufnr)
|
||||||
|
builtin.live_grep({ default_text = current_input, type_filter = input })
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
|
||||||
|
function custom_actions.to_live_grep_args(prompt_bufnr)
|
||||||
|
local current_input = action_state.get_current_line()
|
||||||
|
|
||||||
|
-- Close and reopen a prompt with live_grep_args
|
||||||
|
actions.close(prompt_bufnr)
|
||||||
|
require("telescope").extensions.live_grep_args.live_grep_args({ default_text = current_input })
|
||||||
|
end
|
||||||
|
|
||||||
|
function custom_actions.set_folders(prompt_bufnr)
|
||||||
|
local current_input = action_state.get_current_line()
|
||||||
|
|
||||||
|
local data = {}
|
||||||
|
scan.scan_dir(vim.loop.cwd(), {
|
||||||
|
hidden = true,
|
||||||
|
only_dirs = true,
|
||||||
|
respect_gitignore = true,
|
||||||
|
on_insert = function(entry)
|
||||||
|
table.insert(data, entry .. "/")
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
table.insert(data, 1, "./")
|
||||||
|
|
||||||
|
actions.close(prompt_bufnr)
|
||||||
|
-- Create a new picker with Telescope to select folders we want to filter in
|
||||||
|
pickers.new({
|
||||||
|
prompt_title = 'Select folders for current ("' .. current_input .. '") search',
|
||||||
|
finder = finders.new_table { results = data, entry_maker = make_entry.gen_from_file {} },
|
||||||
|
previewer = conf.file_previewer {},
|
||||||
|
sorter = conf.file_sorter {},
|
||||||
|
attach_mappings = function(prompt_bufnr2)
|
||||||
|
action_set.select:replace(function()
|
||||||
|
local current_picker = action_state.get_current_picker(prompt_bufnr2)
|
||||||
|
|
||||||
|
local dirs = {}
|
||||||
|
local selections = current_picker:get_multi_selection()
|
||||||
|
if vim.tbl_isempty(selections) then
|
||||||
|
table.insert(dirs, action_state.get_selected_entry().value)
|
||||||
|
else
|
||||||
|
for _, selection in ipairs(selections) do
|
||||||
|
table.insert(dirs, selection.value)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
actions.close(prompt_bufnr2)
|
||||||
|
builtin.live_grep({ default_text = current_input, search_dirs = dirs })
|
||||||
|
end)
|
||||||
|
return true
|
||||||
|
|
||||||
|
end,
|
||||||
|
}):find()
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
function custom_actions.set_files(prompt_bufnr)
|
||||||
|
local current_input = action_state.get_current_line()
|
||||||
|
local find_command = {"rg", "--files", "--color=never", "--no-heading"}
|
||||||
|
actions.close(prompt_bufnr)
|
||||||
|
if current_input ~= "" then
|
||||||
|
find_command = {"rg", "--color=never", "--no-heading", "-l", current_input}
|
||||||
|
end
|
||||||
|
|
||||||
|
local opts = {
|
||||||
|
entry_maker = make_entry.gen_from_file(),
|
||||||
|
find_command = find_command,
|
||||||
|
}
|
||||||
|
|
||||||
|
print(vim.inspect(find_command))
|
||||||
|
-- Create a new picker with Telescope to select files we want to filter in
|
||||||
|
pickers
|
||||||
|
.new(opts, {
|
||||||
|
prompt_title = 'Select files for current ("' .. current_input .. '") search',
|
||||||
|
__locations_input = true,
|
||||||
|
finder = finders.new_oneshot_job(find_command, opts),
|
||||||
|
previewer = conf.grep_previewer(opts),
|
||||||
|
sorter = conf.file_sorter(opts),
|
||||||
|
attach_mappings = function(prompt_bufnr2)
|
||||||
|
actions.select_default:replace(function()
|
||||||
|
local current_picker = action_state.get_current_picker(prompt_bufnr2)
|
||||||
|
|
||||||
|
local files = {}
|
||||||
|
local selections = current_picker:get_multi_selection()
|
||||||
|
if vim.tbl_isempty(selections) then
|
||||||
|
local entry = action_state.get_selected_entry()
|
||||||
|
table.insert(files, entry.value)
|
||||||
|
else
|
||||||
|
for _, selection in ipairs(selections) do
|
||||||
|
table.insert(files, selection.value)
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Close the preview picker and select a new one, restricted to the files selected
|
||||||
|
actions.close(prompt_bufnr2)
|
||||||
|
builtin.live_grep({ default_text = current_input, search_dirs = files })
|
||||||
|
end)
|
||||||
|
return true
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
:find()
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
local options = {
|
local options = {
|
||||||
defaults = {
|
defaults = {
|
||||||
vimgrep_arguments = {
|
vimgrep_arguments = {
|
||||||
@ -20,15 +242,15 @@ local options = {
|
|||||||
layout_config = {
|
layout_config = {
|
||||||
horizontal = {
|
horizontal = {
|
||||||
prompt_position = "top",
|
prompt_position = "top",
|
||||||
preview_width = 0.55,
|
preview_width = 0.60,
|
||||||
results_width = 0.8,
|
results_width = 0.8,
|
||||||
},
|
},
|
||||||
vertical = {
|
vertical = {
|
||||||
mirror = false,
|
mirror = false,
|
||||||
},
|
},
|
||||||
width = 0.87,
|
width = 0.90,
|
||||||
height = 0.80,
|
height = 0.92,
|
||||||
preview_cutoff = 120,
|
preview_cutoff = 200,
|
||||||
},
|
},
|
||||||
file_sorter = require("telescope.sorters").get_fuzzy_file,
|
file_sorter = require("telescope.sorters").get_fuzzy_file,
|
||||||
file_ignore_patterns = { "node_modules" },
|
file_ignore_patterns = { "node_modules" },
|
||||||
@ -45,11 +267,65 @@ local options = {
|
|||||||
-- Developer configurations: Not meant for general override
|
-- Developer configurations: Not meant for general override
|
||||||
buffer_previewer_maker = require("telescope.previewers").buffer_previewer_maker,
|
buffer_previewer_maker = require("telescope.previewers").buffer_previewer_maker,
|
||||||
mappings = {
|
mappings = {
|
||||||
n = { ["q"] = require("telescope.actions").close },
|
n = { ["q"] = actions.close },
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
pickers = {
|
||||||
|
buffers = {
|
||||||
|
show_all_buffers = true,
|
||||||
|
sort_lastused = true,
|
||||||
|
mappings = {
|
||||||
|
n = {
|
||||||
|
["d"] = "delete_buffer",
|
||||||
|
},
|
||||||
|
i = {
|
||||||
|
["<C-d>"] = "delete_buffer",
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
find_files = {
|
||||||
|
mappings = {
|
||||||
|
i = {
|
||||||
|
-- Fuzzy refine ("Freeze the current list and start a fuzzy search in the frozen list")
|
||||||
|
["<C-i>"] = actions.to_fuzzy_refine,
|
||||||
|
|
||||||
|
-- Send to qflist or loclist
|
||||||
|
["<C-l>"] = actions.smart_send_to_loclist,
|
||||||
|
["<C-Space>"] = actions.smart_send_to_qflist,
|
||||||
|
|
||||||
|
-- Multi selection open
|
||||||
|
["<CR>"] = custom_actions.multi_selection_open,
|
||||||
|
["<C-v>"] = custom_actions.multi_selection_vsplit,
|
||||||
|
["<C-X>"] = custom_actions.multi_selection_split,
|
||||||
|
["<C-T>"] = custom_actions.multi_selection_tab,
|
||||||
|
},
|
||||||
|
n = i,
|
||||||
|
}
|
||||||
|
},
|
||||||
|
live_grep = {
|
||||||
|
mappings = {
|
||||||
|
i = {
|
||||||
|
-- Fuzzy refine ("Freeze the current list and start a fuzzy search in the frozen list")
|
||||||
|
["<C-i>"] = actions.to_fuzzy_refine,
|
||||||
|
|
||||||
|
-- Send to qflist or loclist
|
||||||
|
["<C-l>"] = actions.smart_send_to_loclist,
|
||||||
|
["<C-Space>"] = actions.smart_send_to_qflist,
|
||||||
|
|
||||||
|
-- To quote prompt -> Pass to live_grep_args
|
||||||
|
["<C-k>"] = custom_actions.to_live_grep_args,
|
||||||
|
|
||||||
|
-- Search for files/folder/extensions
|
||||||
|
["<C-f>"] = custom_actions.set_files,
|
||||||
|
["<C-g>"] = custom_actions.set_folders,
|
||||||
|
["<C-e>"] = custom_actions.set_extension,
|
||||||
|
},
|
||||||
|
n = i,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
extensions_list = { "themes", "terms", "fzf" },
|
extensions_list = { "themes", "terms", "fzf", "macrothis", "live_grep_args" },
|
||||||
extensions = {
|
extensions = {
|
||||||
fzf = {
|
fzf = {
|
||||||
fuzzy = true,
|
fuzzy = true,
|
||||||
@ -57,7 +333,23 @@ local options = {
|
|||||||
override_file_sorter = true,
|
override_file_sorter = true,
|
||||||
case_mode = "smart_case",
|
case_mode = "smart_case",
|
||||||
},
|
},
|
||||||
|
live_grep_args = {
|
||||||
|
auto_quoting = true,
|
||||||
|
mappings = {
|
||||||
|
i = {
|
||||||
|
-- Fuzzy refine ("Freeze the current list and start a fuzzy search in the frozen list")
|
||||||
|
["<C-i>"] = actions.to_fuzzy_refine,
|
||||||
|
|
||||||
|
-- Send to qflist or loclist
|
||||||
|
["<C-l>"] = actions.smart_send_to_loclist,
|
||||||
|
["<C-Space>"] = actions.smart_send_to_qflist,
|
||||||
|
|
||||||
|
-- Quote prompt, for passing parameters to vimgrep
|
||||||
|
["<C-k>"] = lga_actions.quote_prompt(),
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return options
|
return options
|
||||||
|
|||||||
@ -1,5 +1,5 @@
|
|||||||
local options = {
|
local options = {
|
||||||
ensure_installed = { "lua" },
|
ensure_installed = { "lua", "vim", "vimdoc" },
|
||||||
|
|
||||||
highlight = {
|
highlight = {
|
||||||
enable = true,
|
enable = true,
|
||||||
|
|||||||
133
lua/plugins/configs/treesitter_textobjects.lua
Normal file
133
lua/plugins/configs/treesitter_textobjects.lua
Normal file
@ -0,0 +1,133 @@
|
|||||||
|
local M = {}
|
||||||
|
|
||||||
|
M.textobjects = {
|
||||||
|
select = {
|
||||||
|
enable = true,
|
||||||
|
|
||||||
|
-- Automatically jump forward to textobj, similar to targets.vim
|
||||||
|
lookahead = true,
|
||||||
|
|
||||||
|
keymaps = {
|
||||||
|
-- You can use the capture groups defined in textobjects.scm
|
||||||
|
["a="] = { query = "@assignment.outer", desc = "Select outer part of an assignment" },
|
||||||
|
["i="] = { query = "@assignment.inner", desc = "Select inner part of an assignment" },
|
||||||
|
["l="] = { query = "@assignment.lhs", desc = "Select left hand side of an assignment" },
|
||||||
|
["r="] = { query = "@assignment.rhs", desc = "Select right hand side of an assignment" },
|
||||||
|
|
||||||
|
["aa"] = { query = "@parameter.outer", desc = "Select outer part of a parameter/argument" },
|
||||||
|
["ia"] = { query = "@parameter.inner", desc = "Select inner part of a parameter/argument" },
|
||||||
|
|
||||||
|
["ai"] = { query = "@conditional.outer", desc = "Select outer part of a conditional" },
|
||||||
|
["ii"] = { query = "@conditional.inner", desc = "Select inner part of a conditional" },
|
||||||
|
|
||||||
|
["al"] = { query = "@loop.outer", desc = "Select outer part of a loop" },
|
||||||
|
["il"] = { query = "@loop.inner", desc = "Select inner part of a loop" },
|
||||||
|
|
||||||
|
["af"] = { query = "@call.outer", desc = "Select outer part of a function call" },
|
||||||
|
["if"] = { query = "@call.inner", desc = "Select inner part of a function call" },
|
||||||
|
|
||||||
|
["am"] = { query = "@function.outer", desc = "Select outer part of a function def" },
|
||||||
|
["im"] = { query = "@function.inner", desc = "Select inner part of a function def" },
|
||||||
|
|
||||||
|
["ak"] = { query = "@class.outer", desc = "Select outer part of a class" },
|
||||||
|
["ik"] = { query = "@class.inner", desc = "Select inner part of a class" },
|
||||||
|
|
||||||
|
["ac"] = { query = "@comment.outer", desc = "Select outer part of a comment" },
|
||||||
|
["ic"] = { query = "@comment.inner", desc = "Select inner part of a comment" },
|
||||||
|
},
|
||||||
|
},
|
||||||
|
move = {
|
||||||
|
enable = true,
|
||||||
|
-- Whether to set jumps in the jumplist
|
||||||
|
set_jumps = true,
|
||||||
|
goto_next_start = {
|
||||||
|
["]a"] = { query = "@parameter.outer", desc = "Goto next start outer parameter" },
|
||||||
|
["]i"] = { query = "@conditional.outer", desc = "Goto next start outer conditional" },
|
||||||
|
["]l"] = { query = "@loop.outer", desc = "Goto next start outer loop" },
|
||||||
|
["]f"] = { query = "@call.outer", desc = "Goto next start outer call" },
|
||||||
|
["]m"] = { query = "@function.outer", desc = "Goto next start outer function" },
|
||||||
|
["]k"] = { query = "@class.outer", desc = "Goto next start outer class" },
|
||||||
|
["]c"] = { query = "@comment.outer", desc = "Goto next start outer comment" },
|
||||||
|
},
|
||||||
|
goto_next_end = {
|
||||||
|
["]A"] = { query = "@parameter.outer", desc = "Goto next end outer parameter" },
|
||||||
|
["]I"] = { query = "@conditional.outer", desc = "Goto next end outer conditional" },
|
||||||
|
["]L"] = { query = "@loop.outer", desc = "Goto next end outer loop" },
|
||||||
|
["]F"] = { query = "@call.outer", desc = "Goto next end outer call" },
|
||||||
|
["]M"] = { query = "@function.outer", desc = "Goto next end outer function" },
|
||||||
|
["]K"] = { query = "@class.outer", desc = "Goto next end outer class" },
|
||||||
|
["]C"] = { query = "@comment.outer", desc = "Goto next end outer comment" },
|
||||||
|
},
|
||||||
|
goto_previous_start = {
|
||||||
|
["[a"] = { query = "@parameter.outer", desc = "Goto previous start outer parameter" },
|
||||||
|
["[i"] = { query = "@conditional.outer", desc = "Goto previous start outer conditional" },
|
||||||
|
["[l"] = { query = "@loop.outer", desc = "Goto previous start outer loop" },
|
||||||
|
["[f"] = { query = "@call.outer", desc = "Goto previous start outer call" },
|
||||||
|
["[m"] = { query = "@function.outer", desc = "Goto previous start outer function" },
|
||||||
|
["[k"] = { query = "@class.outer", desc = "Goto previous start outer class" },
|
||||||
|
["[c"] = { query = "@comment.outer", desc = "Goto previous start outer comment" },
|
||||||
|
},
|
||||||
|
goto_previous_end = {
|
||||||
|
["[A"] = { query = "@parameter.outer", desc = "Goto previous end outer parameter" },
|
||||||
|
["[I"] = { query = "@conditional.outer", desc = "Goto previous end outer conditional" },
|
||||||
|
["[L"] = { query = "@loop.outer", desc = "Goto previous end outer loop" },
|
||||||
|
["[F"] = { query = "@call.outer", desc = "Goto previous end outer call" },
|
||||||
|
["[M"] = { query = "@function.outer", desc = "Goto previous end outer function" },
|
||||||
|
["[K"] = { query = "@class.outer", desc = "Goto previous end outer class" },
|
||||||
|
["[C"] = { query = "@comment.outer", desc = "Goto previous end outer comment" },
|
||||||
|
},
|
||||||
|
},
|
||||||
|
|
||||||
|
swap = {
|
||||||
|
enable = true,
|
||||||
|
|
||||||
|
swap_next = {
|
||||||
|
["<leader>na"] = { query = "@parameter.inner", desc = "Swap with next inner parameter" },
|
||||||
|
["<leader>ni"] = { query = "@conditional.outer", desc = "Swap with next outer conditional" },
|
||||||
|
["<leader>nl"] = { query = "@loop.outer", desc = "Swap with next outer loop" },
|
||||||
|
["<leader>nf"] = { query = "@call.outer", desc = "Swap with next outer call" },
|
||||||
|
["<leader>nm"] = { query = "@function.outer", desc = "Swap with next outer function" },
|
||||||
|
["<leader>nk"] = { query = "@class.outer", desc = "Swap with next outer class" },
|
||||||
|
["<leader>nc"] = { query = "@comment.outer", desc = "Swap with next outer comment" },
|
||||||
|
|
||||||
|
["<leader>nA"] = { query = "@parameter.outer", desc = "Swap with next outer parameter" },
|
||||||
|
["<leader>nI"] = { query = "@conditional.inner", desc = "Swap with next inner conditional" },
|
||||||
|
["<leader>nL"] = { query = "@loop.inner", desc = "Swap with next inner loop" },
|
||||||
|
["<leader>nF"] = { query = "@call.inner", desc = "Swap with next inner call" },
|
||||||
|
["<leader>nM"] = { query = "@function.inner", desc = "Swap with next inner function" },
|
||||||
|
["<leader>nK"] = { query = "@class.inner", desc = "Swap with next inner class" },
|
||||||
|
["<leader>nC"] = { query = "@comment.inner", desc = "Swap with next inner comment" },
|
||||||
|
},
|
||||||
|
swap_previous = {
|
||||||
|
["<leader>pa"] = { query = "@parameter.inner", desc = "Swap with previous inner parameter" },
|
||||||
|
["<leader>pi"] = { query = "@conditional.outer", desc = "Swap with previous outer conditional" },
|
||||||
|
["<leader>pl"] = { query = "@loop.outer", desc = "Swap with previous outer loop" },
|
||||||
|
["<leader>pf"] = { query = "@call.outer", desc = "Swap with previous outer call" },
|
||||||
|
["<leader>pm"] = { query = "@function.outer", desc = "Swap with previous outer function" },
|
||||||
|
["<leader>pk"] = { query = "@class.outer", desc = "Swap with previous outer class" },
|
||||||
|
["<leader>pc"] = { query = "@comment.outer", desc = "Swap with previous outer comment" },
|
||||||
|
|
||||||
|
["<leader>pA"] = { query = "@parameter.outer", desc = "Swap with previous outer parameter" },
|
||||||
|
["<leader>pI"] = { query = "@conditional.inner", desc = "Swap with previous inner conditional" },
|
||||||
|
["<leader>pL"] = { query = "@loop.inner", desc = "Swap with previous inner loop" },
|
||||||
|
["<leader>pF"] = { query = "@call.inner", desc = "Swap with previous inner call" },
|
||||||
|
["<leader>pM"] = { query = "@function.inner", desc = "Swap with previous inner function" },
|
||||||
|
["<leader>pK"] = { query = "@class.inner", desc = "Swap with previous inner class" },
|
||||||
|
["<leader>pC"] = { query = "@comment.inner", desc = "Swap with previous inner comment" },
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
-- local ts_repeat_move = require "nvim-treesitter.textobjects.repeatable_move"
|
||||||
|
|
||||||
|
-- Repeat movement with ; and ,
|
||||||
|
-- vim.keymap.set({"n", "x", "o"}, ",", ts_repeat_move.repeat_last_move_next)
|
||||||
|
-- vim.keymap.set({"n", "x", "o"}, ",", ts_repeat_move.repeat_last_move_previous)
|
||||||
|
|
||||||
|
-- Optionnally, make builtin f, F, t, T also repeatable with ; and ,
|
||||||
|
-- vim.keymap.set({"n", "x", "o"}, "f", ts_repeat_move.builtin_f)
|
||||||
|
-- vim.keymap.set({"n", "x", "o"}, "F", ts_repeat_move.builtin_F)
|
||||||
|
-- vim.keymap.set({"n", "x", "o"}, "t", ts_repeat_move.builtin_t)
|
||||||
|
-- vim.keymap.set({"n", "x", "o"}, "T", ts_repeat_move.builtin_T)
|
||||||
|
|
||||||
|
return M
|
||||||
@ -3,6 +3,145 @@
|
|||||||
local default_plugins = {
|
local default_plugins = {
|
||||||
|
|
||||||
"nvim-lua/plenary.nvim",
|
"nvim-lua/plenary.nvim",
|
||||||
|
"rebelot/kanagawa.nvim",
|
||||||
|
{
|
||||||
|
"iamcco/markdown-preview.nvim",
|
||||||
|
run = "cd app && npm install",
|
||||||
|
lazy = false,
|
||||||
|
setup = function()
|
||||||
|
vim.g.mkdp_filetypes = { "markdown" }
|
||||||
|
end,
|
||||||
|
ft = { "markdown" },
|
||||||
|
},
|
||||||
|
{ "tpope/vim-fugitive", lazy = false },
|
||||||
|
{ "rbong/vim-flog", lazy = false },
|
||||||
|
{ "tpope/vim-surround", lazy = false },
|
||||||
|
{ "tpope/vim-obsession", lazy = false },
|
||||||
|
{ "preservim/tagbar", lazy = false },
|
||||||
|
{ "ludovicchabant/vim-gutentags", lazy = false },
|
||||||
|
{ "emaniacs/vim-rest-console", lazy = false },
|
||||||
|
{ "mfussenegger/nvim-dap", lazy = false },
|
||||||
|
{
|
||||||
|
"rcarriga/nvim-dap-ui",
|
||||||
|
dependencies = {
|
||||||
|
"mfussenegger/nvim-dap",
|
||||||
|
"nvim-neotest/nvim-nio",
|
||||||
|
},
|
||||||
|
lazy = false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"mfussenegger/nvim-dap-python",
|
||||||
|
dependencies = {
|
||||||
|
"mfussenegger/nvim-dap",
|
||||||
|
"rcarriga/nvim-dap-ui",
|
||||||
|
},
|
||||||
|
lazy = false,
|
||||||
|
init = function()
|
||||||
|
require("dap-python").setup "python"
|
||||||
|
-- Setup nvim-dap-ui also
|
||||||
|
require("dapui").setup()
|
||||||
|
end,
|
||||||
|
config = function(_, _)
|
||||||
|
local dap = require "dap"
|
||||||
|
vim.api.nvim_set_hl(0, "dark-orange", { bg = "#402c16" })
|
||||||
|
vim.fn.sign_define("DapBreakpoint", { text = "🛑", texthl = "", linehl = "", numhl = "" })
|
||||||
|
vim.fn.sign_define("DapStopped", { text = "", texthl = "", linehl = "dark-orange", numhl = "" })
|
||||||
|
dap.defaults.fallback.terminal_win_cmd = "tabnew"
|
||||||
|
dap.defaults.fallback.focus_terminal = true
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"Weissle/persistent-breakpoints.nvim",
|
||||||
|
lazy = false,
|
||||||
|
config = function(_, _)
|
||||||
|
require("persistent-breakpoints").setup {
|
||||||
|
load_breakpoints_event = { "BufReadPost" },
|
||||||
|
}
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
{ "nvim-telescope/telescope-live-grep-args.nvim", lazy = false },
|
||||||
|
{ "nvim-telescope/telescope-dap.nvim", lazy = false },
|
||||||
|
{
|
||||||
|
"harrisoncramer/gitlab.nvim",
|
||||||
|
dependencies = {
|
||||||
|
"MunifTanjim/nui.nvim",
|
||||||
|
"nvim-lua/plenary.nvim",
|
||||||
|
"sindrets/diffview.nvim",
|
||||||
|
"stevearc/dressing.nvim", -- Recommended but not required. Better UI for pickers.
|
||||||
|
"nvim-tree/nvim-web-devicons", -- Recommended but not required. Icons in discussion tree.
|
||||||
|
},
|
||||||
|
enabled = true,
|
||||||
|
lazy = false,
|
||||||
|
build = function()
|
||||||
|
require("gitlab.server").build(true)
|
||||||
|
end, -- Builds the Go binary
|
||||||
|
opts = function()
|
||||||
|
return require "plugins.configs.gitlab"
|
||||||
|
end,
|
||||||
|
config = function(_, opts)
|
||||||
|
require("gitlab").setup(opts)
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"sindrets/diffview.nvim",
|
||||||
|
lazy = false,
|
||||||
|
opts = function()
|
||||||
|
return require "plugins.configs.diffview"
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
|
||||||
|
{ "nvim-telescope/telescope-fzf-native.nvim", build = "make" },
|
||||||
|
|
||||||
|
{
|
||||||
|
"stevearc/quicker.nvim",
|
||||||
|
opts = {},
|
||||||
|
init = function()
|
||||||
|
require("quicker").setup()
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
"chentoast/marks.nvim",
|
||||||
|
lazy = false,
|
||||||
|
init = function()
|
||||||
|
require("marks").setup {
|
||||||
|
default_mappings = true,
|
||||||
|
signs = true,
|
||||||
|
mappings = {},
|
||||||
|
}
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
"stevearc/conform.nvim",
|
||||||
|
opts = {},
|
||||||
|
init = function()
|
||||||
|
require("conform").setup {
|
||||||
|
formatters_by_ft = {
|
||||||
|
lua = { "stylua" },
|
||||||
|
-- You can use a function here to determine the formatters dynamically
|
||||||
|
python = function(bufnr)
|
||||||
|
if require("conform").get_formatter_info("ruff_format", bufnr).available then
|
||||||
|
return { "isort", "black" }
|
||||||
|
-- return { "ruff_format" }
|
||||||
|
else
|
||||||
|
return { "isort", "black" }
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
-- javascript = { "prettierd", "prettier", stop_after_first = true },
|
||||||
|
},
|
||||||
|
options = {
|
||||||
|
lang_to_formatters = {
|
||||||
|
json = { "jq" },
|
||||||
|
},
|
||||||
|
},
|
||||||
|
format_on_save = {
|
||||||
|
timeout_ms = 1000,
|
||||||
|
lsp_format = "fallback",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
|
||||||
{
|
{
|
||||||
"NvChad/base46",
|
"NvChad/base46",
|
||||||
@ -19,7 +158,7 @@ local default_plugins = {
|
|||||||
},
|
},
|
||||||
|
|
||||||
{
|
{
|
||||||
"NvChad/nvterm",
|
"zbirenbaum/nvterm",
|
||||||
init = function()
|
init = function()
|
||||||
require("core.utils").load_mappings "nvterm"
|
require("core.utils").load_mappings "nvterm"
|
||||||
end,
|
end,
|
||||||
@ -31,9 +170,7 @@ local default_plugins = {
|
|||||||
|
|
||||||
{
|
{
|
||||||
"NvChad/nvim-colorizer.lua",
|
"NvChad/nvim-colorizer.lua",
|
||||||
init = function()
|
event = "User FilePost",
|
||||||
require("core.utils").lazy_load "nvim-colorizer.lua"
|
|
||||||
end,
|
|
||||||
config = function(_, opts)
|
config = function(_, opts)
|
||||||
require("colorizer").setup(opts)
|
require("colorizer").setup(opts)
|
||||||
|
|
||||||
@ -61,6 +198,7 @@ local default_plugins = {
|
|||||||
init = function()
|
init = function()
|
||||||
require("core.utils").lazy_load "indent-blankline.nvim"
|
require("core.utils").lazy_load "indent-blankline.nvim"
|
||||||
end,
|
end,
|
||||||
|
event = "User FilePost",
|
||||||
opts = function()
|
opts = function()
|
||||||
return require("plugins.configs.others").blankline
|
return require("plugins.configs.others").blankline
|
||||||
end,
|
end,
|
||||||
@ -73,9 +211,7 @@ local default_plugins = {
|
|||||||
|
|
||||||
{
|
{
|
||||||
"nvim-treesitter/nvim-treesitter",
|
"nvim-treesitter/nvim-treesitter",
|
||||||
init = function()
|
event = { "BufReadPost", "BufNewFile" },
|
||||||
require("core.utils").lazy_load "nvim-treesitter"
|
|
||||||
end,
|
|
||||||
cmd = { "TSInstall", "TSBufEnable", "TSBufDisable", "TSModuleInfo" },
|
cmd = { "TSInstall", "TSBufEnable", "TSBufDisable", "TSModuleInfo" },
|
||||||
build = ":TSUpdate",
|
build = ":TSUpdate",
|
||||||
opts = function()
|
opts = function()
|
||||||
@ -87,25 +223,18 @@ local default_plugins = {
|
|||||||
end,
|
end,
|
||||||
},
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
"nvim-treesitter/nvim-treesitter-textobjects",
|
||||||
|
lazy = false,
|
||||||
|
config = function()
|
||||||
|
require("nvim-treesitter.configs").setup(require "plugins.configs.treesitter_textobjects")
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
|
||||||
-- git stuff
|
-- git stuff
|
||||||
{
|
{
|
||||||
"lewis6991/gitsigns.nvim",
|
"lewis6991/gitsigns.nvim",
|
||||||
ft = { "gitcommit", "diff" },
|
event = "User FilePost",
|
||||||
init = function()
|
|
||||||
-- load gitsigns only when a git file is opened
|
|
||||||
vim.api.nvim_create_autocmd({ "BufRead" }, {
|
|
||||||
group = vim.api.nvim_create_augroup("GitSignsLazyLoad", { clear = true }),
|
|
||||||
callback = function()
|
|
||||||
vim.fn.system("git -C " .. '"' .. vim.fn.expand "%:p:h" .. '"' .. " rev-parse")
|
|
||||||
if vim.v.shell_error == 0 then
|
|
||||||
vim.api.nvim_del_augroup_by_name "GitSignsLazyLoad"
|
|
||||||
vim.schedule(function()
|
|
||||||
require("lazy").load { plugins = { "gitsigns.nvim" } }
|
|
||||||
end)
|
|
||||||
end
|
|
||||||
end,
|
|
||||||
})
|
|
||||||
end,
|
|
||||||
opts = function()
|
opts = function()
|
||||||
return require("plugins.configs.others").gitsigns
|
return require("plugins.configs.others").gitsigns
|
||||||
end,
|
end,
|
||||||
@ -128,7 +257,9 @@ local default_plugins = {
|
|||||||
|
|
||||||
-- custom nvchad cmd to install all mason binaries listed
|
-- custom nvchad cmd to install all mason binaries listed
|
||||||
vim.api.nvim_create_user_command("MasonInstallAll", function()
|
vim.api.nvim_create_user_command("MasonInstallAll", function()
|
||||||
|
if opts.ensure_installed and #opts.ensure_installed > 0 then
|
||||||
vim.cmd("MasonInstall " .. table.concat(opts.ensure_installed, " "))
|
vim.cmd("MasonInstall " .. table.concat(opts.ensure_installed, " "))
|
||||||
|
end
|
||||||
end, {})
|
end, {})
|
||||||
|
|
||||||
vim.g.mason_binaries_list = opts.ensure_installed
|
vim.g.mason_binaries_list = opts.ensure_installed
|
||||||
@ -137,9 +268,7 @@ local default_plugins = {
|
|||||||
|
|
||||||
{
|
{
|
||||||
"neovim/nvim-lspconfig",
|
"neovim/nvim-lspconfig",
|
||||||
init = function()
|
event = "User FilePost",
|
||||||
require("core.utils").lazy_load "nvim-lspconfig"
|
|
||||||
end,
|
|
||||||
config = function()
|
config = function()
|
||||||
require "plugins.configs.lspconfig"
|
require "plugins.configs.lspconfig"
|
||||||
end,
|
end,
|
||||||
@ -211,6 +340,166 @@ local default_plugins = {
|
|||||||
end,
|
end,
|
||||||
},
|
},
|
||||||
|
|
||||||
|
-- Save and load macro / register
|
||||||
|
{
|
||||||
|
"desdic/macrothis.nvim",
|
||||||
|
opts = {},
|
||||||
|
keys = {
|
||||||
|
{
|
||||||
|
"<Leader>kkd",
|
||||||
|
function()
|
||||||
|
require("macrothis").delete()
|
||||||
|
end,
|
||||||
|
desc = "[D]elete",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<Leader>kke",
|
||||||
|
function()
|
||||||
|
require("macrothis").edit()
|
||||||
|
end,
|
||||||
|
desc = "[E]dit",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<Leader>kkl",
|
||||||
|
function()
|
||||||
|
require("macrothis").load()
|
||||||
|
end,
|
||||||
|
desc = "[L]oad",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<Leader>kkn",
|
||||||
|
function()
|
||||||
|
require("macrothis").rename()
|
||||||
|
end,
|
||||||
|
desc = "Re[n]ame",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<Leader>kkq",
|
||||||
|
function()
|
||||||
|
require("macrothis").quickfix()
|
||||||
|
end,
|
||||||
|
desc = "Run macro on all files in [q]uickfix",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<Leader>kkr",
|
||||||
|
function()
|
||||||
|
require("macrothis").run()
|
||||||
|
end,
|
||||||
|
desc = "[R]un macro",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<Leader>kks",
|
||||||
|
function()
|
||||||
|
require("macrothis").save()
|
||||||
|
end,
|
||||||
|
desc = "[S]ave",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<Leader>kkx",
|
||||||
|
function()
|
||||||
|
require("macrothis").register()
|
||||||
|
end,
|
||||||
|
desc = "Edit register",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<Leader>kkp",
|
||||||
|
function()
|
||||||
|
require("macrothis").copy_register_printable()
|
||||||
|
end,
|
||||||
|
desc = "Co[p]y register as printable",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"<Leader>kkm",
|
||||||
|
function()
|
||||||
|
require("macrothis").copy_macro_printable()
|
||||||
|
end,
|
||||||
|
desc = "Copy [m]acro as printable",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"onsails/diaglist.nvim",
|
||||||
|
lazy = false,
|
||||||
|
debug = false,
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
"anuvyklack/hydra.nvim",
|
||||||
|
lazy = false,
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
"gioele/vim-autoswap",
|
||||||
|
lazy = false,
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
"natecraddock/workspaces.nvim",
|
||||||
|
lazy = false,
|
||||||
|
|
||||||
|
config = function()
|
||||||
|
require("workspaces").setup {
|
||||||
|
hooks = {
|
||||||
|
open = { "Telescope find_files" },
|
||||||
|
},
|
||||||
|
}
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
"mangelozzi/rgflow.nvim",
|
||||||
|
lazy = false,
|
||||||
|
|
||||||
|
config = function()
|
||||||
|
require("rgflow").setup {
|
||||||
|
-- Set the default rip grep flags and options for when running a search via
|
||||||
|
-- RgFlow. Once changed via the UI, the previous search flags are used for
|
||||||
|
-- each subsequent search (until Neovim restarts).
|
||||||
|
cmd_flags = "--smart-case --fixed-strings --ignore --max-columns 200",
|
||||||
|
|
||||||
|
-- Mappings to trigger RgFlow functions
|
||||||
|
default_trigger_mappings = true,
|
||||||
|
-- These mappings are only active when the RgFlow UI (panel) is open
|
||||||
|
default_ui_mappings = true,
|
||||||
|
-- QuickFix window only mapping
|
||||||
|
default_quickfix_mappings = true,
|
||||||
|
}
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
"yorickpeterse/nvim-window",
|
||||||
|
lazy = false,
|
||||||
|
config = function()
|
||||||
|
require("nvim-window").setup {
|
||||||
|
normal_hl = "Normal",
|
||||||
|
hint_hl = "Bold",
|
||||||
|
border = "single",
|
||||||
|
}
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
"sindrets/winshift.nvim",
|
||||||
|
lazy = false,
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
"kdheepak/lazygit.nvim",
|
||||||
|
lazy = false,
|
||||||
|
config = function()
|
||||||
|
require("lazy").setup {
|
||||||
|
{
|
||||||
|
"kdheepak/lazygit.nvim",
|
||||||
|
-- optional for floating window border decoration
|
||||||
|
dependencies = {
|
||||||
|
"nvim-lua/plenary.nvim",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
end,
|
||||||
|
},
|
||||||
|
|
||||||
-- file managing , picker etc
|
-- file managing , picker etc
|
||||||
{
|
{
|
||||||
"nvim-tree/nvim-tree.lua",
|
"nvim-tree/nvim-tree.lua",
|
||||||
@ -229,7 +518,7 @@ local default_plugins = {
|
|||||||
|
|
||||||
{
|
{
|
||||||
"nvim-telescope/telescope.nvim",
|
"nvim-telescope/telescope.nvim",
|
||||||
dependencies = { "nvim-treesitter/nvim-treesitter", { "nvim-telescope/telescope-fzf-native.nvim", build = "make" } },
|
dependencies = { "nvim-treesitter/nvim-treesitter" },
|
||||||
cmd = "Telescope",
|
cmd = "Telescope",
|
||||||
init = function()
|
init = function()
|
||||||
require("core.utils").load_mappings "telescope"
|
require("core.utils").load_mappings "telescope"
|
||||||
@ -252,6 +541,7 @@ local default_plugins = {
|
|||||||
-- Only load whichkey after all the gui
|
-- Only load whichkey after all the gui
|
||||||
{
|
{
|
||||||
"folke/which-key.nvim",
|
"folke/which-key.nvim",
|
||||||
|
lazy = false,
|
||||||
keys = { "<leader>", "<c-r>", "<c-w>", '"', "'", "`", "c", "v", "g" },
|
keys = { "<leader>", "<c-r>", "<c-w>", '"', "'", "`", "c", "v", "g" },
|
||||||
init = function()
|
init = function()
|
||||||
require("core.utils").load_mappings "whichkey"
|
require("core.utils").load_mappings "whichkey"
|
||||||
@ -262,6 +552,51 @@ local default_plugins = {
|
|||||||
require("which-key").setup(opts)
|
require("which-key").setup(opts)
|
||||||
end,
|
end,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"ThePrimeagen/harpoon",
|
||||||
|
branch = "harpoon2",
|
||||||
|
dependencies = { "nvim-lua/plenary.nvim" },
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"folke/noice.nvim",
|
||||||
|
event = "VeryLazy",
|
||||||
|
opts = function()
|
||||||
|
return require "plugins.configs.noice"
|
||||||
|
end,
|
||||||
|
init = function()
|
||||||
|
require("noice").setup {
|
||||||
|
routes = {
|
||||||
|
{
|
||||||
|
view = "notify",
|
||||||
|
filter = { event = "msg_showmode" },
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
-- require("notify").setup({
|
||||||
|
-- background_colour = "#000000"
|
||||||
|
-- })
|
||||||
|
end,
|
||||||
|
dependencies = {
|
||||||
|
"MunifTanjim/nui.nvim",
|
||||||
|
-- "rcarriga/nvim-notify",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"folke/todo-comments.nvim",
|
||||||
|
lazy = false,
|
||||||
|
dependencies = { "nvim-lua/plenary.nvim" },
|
||||||
|
opts = {
|
||||||
|
-- your configuration comes here
|
||||||
|
-- or leave it empty to use the default settings
|
||||||
|
-- refer to the configuration section below
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"folke/trouble.nvim",
|
||||||
|
lazy = false,
|
||||||
|
cmd = "Trouble",
|
||||||
|
opts = {},
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
local config = require("core.utils").load_config()
|
local config = require("core.utils").load_config()
|
||||||
@ -271,3 +606,4 @@ if #config.plugins > 0 then
|
|||||||
end
|
end
|
||||||
|
|
||||||
require("lazy").setup(default_plugins, config.lazy_nvim)
|
require("lazy").setup(default_plugins, config.lazy_nvim)
|
||||||
|
require "plugins.configs.ruff_lsp"
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user