Compare commits
23 Commits
95d8c16621
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
| ba5fd1c33b | |||
| ff14f16bbd | |||
| 00b5d44396 | |||
| 9a6765df45 | |||
| 280c00b272 | |||
| 31a03cac7b | |||
| f59a288d59 | |||
| 5def28d407 | |||
| 2dec8af915 | |||
| 27c50224f7 | |||
| 39967dc120 | |||
| bea244a4aa | |||
| f08562558b | |||
| bc5ddb6dc7 | |||
| f213c20d23 | |||
| 481c127583 | |||
| e0286197f8 | |||
| 6fefe27f0e | |||
| 82143dea23 | |||
| 144d2b11cf | |||
| 44199d81b4 | |||
| 6401649361 | |||
| ee385eb5da |
1
after/ftplugin/dap-view-term.lua
Normal file
1
after/ftplugin/dap-view-term.lua
Normal file
@@ -0,0 +1 @@
|
|||||||
|
vim.o.signcolumn = 'no'
|
||||||
4
init.lua
4
init.lua
@@ -1,3 +1,5 @@
|
|||||||
|
vim.loader.enable()
|
||||||
|
|
||||||
vim.g.mapleader = ' '
|
vim.g.mapleader = ' '
|
||||||
vim.g.maplocalleader = ' '
|
vim.g.maplocalleader = ' '
|
||||||
|
|
||||||
@@ -11,7 +13,7 @@ end
|
|||||||
pcall(function() require('local') end)
|
pcall(function() require('local') end)
|
||||||
|
|
||||||
local lazypath = vim.fn.stdpath('data') .. '/lazy/lazy.nvim'
|
local lazypath = vim.fn.stdpath('data') .. '/lazy/lazy.nvim'
|
||||||
if not vim.loop.fs_stat(lazypath) then
|
if not vim.uv.fs_stat(lazypath) then
|
||||||
vim.fn.system({ 'git', 'clone', '--filter=blob:none',
|
vim.fn.system({ 'git', 'clone', '--filter=blob:none',
|
||||||
'https://github.com/folke/lazy.nvim.git', '--branch=stable', lazypath })
|
'https://github.com/folke/lazy.nvim.git', '--branch=stable', lazypath })
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -36,6 +36,7 @@ local kanagawa = {
|
|||||||
-- Don't lighlight TODO specially in comments
|
-- Don't lighlight TODO specially in comments
|
||||||
for _, todo_group in pairs({
|
for _, todo_group in pairs({
|
||||||
'confTodo',
|
'confTodo',
|
||||||
|
'mojoTodo',
|
||||||
'ps1CommentTodo',
|
'ps1CommentTodo',
|
||||||
'pythonTodo',
|
'pythonTodo',
|
||||||
'zshTodo',
|
'zshTodo',
|
||||||
|
|||||||
@@ -1,54 +1,3 @@
|
|||||||
-- Language servers
|
|
||||||
local ensure_installed = {
|
|
||||||
'clangd', -- C/C++
|
|
||||||
'lua_ls', -- Lua
|
|
||||||
'opencl_ls', -- OpenCL
|
|
||||||
'harper_ls', -- Spelling & grammar
|
|
||||||
'marksman', -- Markdown
|
|
||||||
'tinymist', -- Typst
|
|
||||||
}
|
|
||||||
|
|
||||||
if vim.fn.executable('npm') == 1 then
|
|
||||||
local ensure_install_from_npm = {
|
|
||||||
'ansiblels', -- Ansible
|
|
||||||
'bashls', -- Bash
|
|
||||||
'docker_compose_language_service', -- Docker Compose
|
|
||||||
'dockerls', -- Dockerfile
|
|
||||||
'html', -- HTML
|
|
||||||
'jsonls', -- JSON
|
|
||||||
'pyright', -- Python
|
|
||||||
'vimls', -- VimScript
|
|
||||||
'yamlls', -- YAML
|
|
||||||
}
|
|
||||||
for _, package in ipairs(ensure_install_from_npm) do
|
|
||||||
table.insert(ensure_installed, package)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
if vim.fn.executable('pip') == 1 then
|
|
||||||
local ensure_install_from_pip = {
|
|
||||||
'cmake', -- CMake
|
|
||||||
'esbonio', -- Sphinx
|
|
||||||
'ruff', -- Python
|
|
||||||
}
|
|
||||||
for _, package in ipairs(ensure_install_from_pip) do
|
|
||||||
table.insert(ensure_installed, package)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
if vim.fn.executable('go') == 1 then
|
|
||||||
local ensure_installed_from_go = {
|
|
||||||
'gopls', -- Go
|
|
||||||
}
|
|
||||||
for _, package in ipairs(ensure_installed_from_go) do
|
|
||||||
table.insert(ensure_installed, package)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
if vim.fn.has('win32') == 1 then
|
|
||||||
table.insert(ensure_installed, 'powershell_es')
|
|
||||||
end
|
|
||||||
|
|
||||||
return {
|
return {
|
||||||
'neovim/nvim-lspconfig',
|
'neovim/nvim-lspconfig',
|
||||||
dependencies = {
|
dependencies = {
|
||||||
@@ -131,9 +80,48 @@ return {
|
|||||||
end
|
end
|
||||||
|
|
||||||
require('mason').setup()
|
require('mason').setup()
|
||||||
|
|
||||||
|
local language_servers = {
|
||||||
|
'clangd', -- C/C++
|
||||||
|
'lua_ls', -- Lua
|
||||||
|
'opencl_ls', -- OpenCL
|
||||||
|
'harper_ls', -- Spelling & grammar
|
||||||
|
'marksman', -- Markdown
|
||||||
|
'tinymist', -- Typst
|
||||||
|
}
|
||||||
|
|
||||||
|
if vim.fn.executable('npm') == 1 then
|
||||||
|
for _, package in ipairs({
|
||||||
|
'ansiblels', -- Ansible
|
||||||
|
'bashls', -- Bash
|
||||||
|
'docker_compose_language_service', -- Docker Compose
|
||||||
|
'dockerls', -- Dockerfile
|
||||||
|
'html', -- HTML
|
||||||
|
'jsonls', -- JSON
|
||||||
|
'pyright', -- Python
|
||||||
|
'vimls', -- VimScript
|
||||||
|
'yamlls', -- YAML
|
||||||
|
}) do table.insert(language_servers, package) end
|
||||||
|
end
|
||||||
|
|
||||||
|
if vim.fn.executable('pip') == 1 then
|
||||||
|
for _, package in ipairs({
|
||||||
|
'cmake', -- CMake
|
||||||
|
'esbonio', -- Sphinx
|
||||||
|
'ruff', -- Python
|
||||||
|
}) do table.insert(language_servers, package) end
|
||||||
|
end
|
||||||
|
|
||||||
|
if vim.fn.executable('go') == 1 then
|
||||||
|
table.insert(language_servers, 'gopls') -- Go
|
||||||
|
end
|
||||||
|
|
||||||
|
if vim.fn.has('win32') == 1 then
|
||||||
|
table.insert(language_servers, 'powershell_es') -- PowerShell
|
||||||
|
end
|
||||||
|
|
||||||
require('mason-lspconfig').setup({
|
require('mason-lspconfig').setup({
|
||||||
automatic_enable = true,
|
ensure_installed = language_servers,
|
||||||
ensure_installed = ensure_installed,
|
|
||||||
})
|
})
|
||||||
|
|
||||||
-- (Dis|en)able harper-ls when spell mode is (dis|en)enabled.
|
-- (Dis|en)able harper-ls when spell mode is (dis|en)enabled.
|
||||||
@@ -236,12 +224,6 @@ return {
|
|||||||
-- Refactoring mappings
|
-- Refactoring mappings
|
||||||
vim.keymap.set('n', '<leader>rn', vim.lsp.buf.rename, opts)
|
vim.keymap.set('n', '<leader>rn', vim.lsp.buf.rename, opts)
|
||||||
|
|
||||||
-- Help mappings
|
|
||||||
-- TODO: v0.10.0 |vim.lsp.start()| now maps |K| to use
|
|
||||||
-- |vim.lsp.buf.hover()| if the server supports it, unless
|
|
||||||
-- |'keywordprg'| was customized before calling |vim.lsp.start()|.
|
|
||||||
vim.keymap.set('n', 'K', vim.lsp.buf.hover, opts)
|
|
||||||
|
|
||||||
-- Format whole buffer mapping
|
-- Format whole buffer mapping
|
||||||
vim.keymap.set('n', '<leader>gq', vim.lsp.buf.format, opts)
|
vim.keymap.set('n', '<leader>gq', vim.lsp.buf.format, opts)
|
||||||
|
|
||||||
@@ -266,10 +248,10 @@ return {
|
|||||||
local mason_registry = require('mason-registry')
|
local mason_registry = require('mason-registry')
|
||||||
if mason_registry.is_installed('harper-ls') then
|
if mason_registry.is_installed('harper-ls') then
|
||||||
-- Disable builtin spell mode highlighting
|
-- Disable builtin spell mode highlighting
|
||||||
vim.cmd.highlight('SpellBad', 'NONE')
|
vim.cmd.highlight('SpellBad', 'NONE')
|
||||||
vim.cmd.highlight('SpellCap', 'NONE')
|
vim.cmd.highlight('SpellCap', 'NONE')
|
||||||
vim.cmd.highlight('SpellLocal', 'NONE')
|
vim.cmd.highlight('SpellLocal', 'NONE')
|
||||||
vim.cmd.highlight('SpellRare', 'NONE')
|
vim.cmd.highlight('SpellRare', 'NONE')
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
}
|
}
|
||||||
|
|||||||
64
lua/plugins/debugger.lua
Normal file
64
lua/plugins/debugger.lua
Normal file
@@ -0,0 +1,64 @@
|
|||||||
|
return {
|
||||||
|
'mfussenegger/nvim-dap',
|
||||||
|
dependencies = {
|
||||||
|
'igorlfs/nvim-dap-view',
|
||||||
|
'kbenzie/mason.nvim',
|
||||||
|
'jay-babu/mason-nvim-dap.nvim',
|
||||||
|
'theHamsta/nvim-dap-virtual-text',
|
||||||
|
'Jorenar/nvim-dap-disasm',
|
||||||
|
},
|
||||||
|
config = function()
|
||||||
|
local dap = require('dap')
|
||||||
|
|
||||||
|
-- Installation
|
||||||
|
local debug_adapters = {
|
||||||
|
'codelldb', -- C/C++/Rust/Zig
|
||||||
|
}
|
||||||
|
|
||||||
|
if vim.fn.executable('pip') == 1 then
|
||||||
|
table.insert(debug_adapters, 'python') -- Python
|
||||||
|
end
|
||||||
|
|
||||||
|
if vim.fn.executable('go') == 1 then
|
||||||
|
table.insert(debug_adapters, 'delve') -- Go
|
||||||
|
end
|
||||||
|
|
||||||
|
require("mason-nvim-dap").setup({
|
||||||
|
ensure_installed = debug_adapters,
|
||||||
|
handlers = {},
|
||||||
|
})
|
||||||
|
|
||||||
|
-- UI plugins
|
||||||
|
require('dap-view').setup({
|
||||||
|
auto_toggle = true,
|
||||||
|
})
|
||||||
|
require('nvim-dap-virtual-text').setup({})
|
||||||
|
require('dap-disasm').setup({
|
||||||
|
dapview_register = true,
|
||||||
|
})
|
||||||
|
|
||||||
|
vim.api.nvim_create_autocmd({ "FileType" }, {
|
||||||
|
pattern = {
|
||||||
|
'dap-float',
|
||||||
|
},
|
||||||
|
callback = function(args)
|
||||||
|
vim.keymap.set("n", "q", "<C-w>q", { buffer = args.buf })
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
|
local widgets = require('dap.ui.widgets')
|
||||||
|
|
||||||
|
-- Mappings
|
||||||
|
vim.keymap.set('n', '<leader>D', vim.cmd.DapViewToggle)
|
||||||
|
vim.keymap.set('n', '<F5>', dap.continue)
|
||||||
|
vim.keymap.set('n', '<F17>', dap.terminate) -- Shift-F5
|
||||||
|
vim.keymap.set('n', '<F9>', dap.toggle_breakpoint)
|
||||||
|
vim.keymap.set('n', '<F21>', vim.cmd.DapViewWatch) -- Shift-F9
|
||||||
|
vim.keymap.set('n', '<F41>', dap.restart) -- Ctrl-Shift-F5
|
||||||
|
vim.keymap.set('n', '<F34>', dap.run_to_cursor) -- Ctrl-F10
|
||||||
|
vim.keymap.set('n', '<F11>', dap.step_into)
|
||||||
|
vim.keymap.set('n', '<F23>', dap.step_out) -- Shift-F11
|
||||||
|
vim.keymap.set('n', '<F10>', dap.step_over)
|
||||||
|
vim.keymap.set('n', '<leader>K', widgets.hover)
|
||||||
|
end,
|
||||||
|
}
|
||||||
@@ -1,6 +1,5 @@
|
|||||||
return {
|
return {
|
||||||
'davidmh/mdx.nvim',
|
'davidmh/mdx.nvim',
|
||||||
config = true,
|
|
||||||
dependencies = {
|
dependencies = {
|
||||||
'nvim-treesitter/nvim-treesitter',
|
'nvim-treesitter/nvim-treesitter',
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
return {
|
return {
|
||||||
'nvim-treesitter/nvim-treesitter',
|
'nvim-treesitter/nvim-treesitter',
|
||||||
|
branch = 'master',
|
||||||
dependencies = {
|
dependencies = {
|
||||||
'nvim-treesitter/nvim-treesitter-textobjects',
|
'nvim-treesitter/nvim-treesitter-textobjects',
|
||||||
{ 'nvim-treesitter/nvim-treesitter-context', opts = {} },
|
{ 'nvim-treesitter/nvim-treesitter-context', opts = {} },
|
||||||
@@ -97,5 +98,10 @@ return {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
|
||||||
|
-- Keymaps
|
||||||
|
vim.keymap.set('n', '<leader>fm', function()
|
||||||
|
vim.o.foldmethod = 'expr'
|
||||||
|
end, {})
|
||||||
end
|
end
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -33,8 +33,18 @@ local noice = {
|
|||||||
|
|
||||||
return {
|
return {
|
||||||
-- noice,
|
-- noice,
|
||||||
{ 'echasnovski/mini.comment', opts = { options = { ignore_blank_line = true } } },
|
{
|
||||||
{ 'tpope/vim-unimpaired', lazy = false },
|
'echasnovski/mini.comment',
|
||||||
|
opts = {
|
||||||
|
options = {
|
||||||
|
ignore_blank_line = true,
|
||||||
|
}
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'tpope/vim-unimpaired',
|
||||||
|
lazy = false,
|
||||||
|
},
|
||||||
{ 'stevearc/dressing.nvim' },
|
{ 'stevearc/dressing.nvim' },
|
||||||
{ 'kevinhwang91/nvim-bqf' },
|
{ 'kevinhwang91/nvim-bqf' },
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -25,10 +25,17 @@ vim.api.nvim_create_autocmd('BufRead', {
|
|||||||
|
|
||||||
-- Start terminals in insert mode
|
-- Start terminals in insert mode
|
||||||
vim.api.nvim_create_autocmd('TermOpen', {
|
vim.api.nvim_create_autocmd('TermOpen', {
|
||||||
group = group, pattern = 'term://*',
|
group = group,
|
||||||
callback = function()
|
pattern = 'term://*',
|
||||||
|
callback = function(args)
|
||||||
|
-- nvim-dap/nvim-dap-view uses terminal buffers in the background which are
|
||||||
|
-- not visible, don't start insert mode if the dap-type variable exists.
|
||||||
|
local success, dap_type = pcall(vim.api.nvim_buf_get_var, args.buf, 'dap-type')
|
||||||
|
if success and dap_type then
|
||||||
|
return
|
||||||
|
end
|
||||||
vim.cmd.startinsert()
|
vim.cmd.startinsert()
|
||||||
end
|
end,
|
||||||
})
|
})
|
||||||
|
|
||||||
-- Automatically press enter when the terminal process exit successfully
|
-- Automatically press enter when the terminal process exit successfully
|
||||||
|
|||||||
@@ -52,7 +52,7 @@ vim.api.nvim_create_user_command('Remove', function(opts)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
-- Actually remove the file using the selected callback.
|
-- Actually remove the file using the selected callback.
|
||||||
vim.loop.fs_unlink(path, callback)
|
vim.uv.fs_unlink(path, callback)
|
||||||
end, { bang = true })
|
end, { bang = true })
|
||||||
|
|
||||||
-- :Move the file associated with the current buffer
|
-- :Move the file associated with the current buffer
|
||||||
@@ -62,7 +62,7 @@ vim.api.nvim_create_user_command('Move', function(opts)
|
|||||||
if vim.fn.isdirectory(dest) ~= 0 then
|
if vim.fn.isdirectory(dest) ~= 0 then
|
||||||
dest = vim.fn.resolve(dest .. '/' .. vim.fn.expand('%:t'))
|
dest = vim.fn.resolve(dest .. '/' .. vim.fn.expand('%:t'))
|
||||||
end
|
end
|
||||||
vim.loop.fs_rename(source, dest, function(err, success)
|
vim.uv.fs_rename(source, dest, function(err, success)
|
||||||
if success then
|
if success then
|
||||||
vim.schedule(function()
|
vim.schedule(function()
|
||||||
vim.cmd.edit(dest)
|
vim.cmd.edit(dest)
|
||||||
@@ -87,7 +87,7 @@ vim.api.nvim_create_user_command('Rename', function(opts)
|
|||||||
dest = vim.fn.resolve(dir .. '/' .. opts.args)
|
dest = vim.fn.resolve(dir .. '/' .. opts.args)
|
||||||
end
|
end
|
||||||
local buffer = vim.api.nvim_get_current_buf()
|
local buffer = vim.api.nvim_get_current_buf()
|
||||||
vim.loop.fs_rename(source, dest, function(err, success)
|
vim.uv.fs_rename(source, dest, function(err, success)
|
||||||
if not success then
|
if not success then
|
||||||
error(err)
|
error(err)
|
||||||
else
|
else
|
||||||
|
|||||||
@@ -29,7 +29,7 @@ vim.keymap.set('', '<leader>p', '"+p', opts)
|
|||||||
vim.keymap.set('', '<leader>P', '"+P', opts)
|
vim.keymap.set('', '<leader>P', '"+P', opts)
|
||||||
|
|
||||||
-- Undo neovim's default mapping of Y to y$
|
-- Undo neovim's default mapping of Y to y$
|
||||||
vim.cmd.unmap('Y')
|
vim.keymap.del('n', 'Y')
|
||||||
|
|
||||||
-- Make nvim :terminal more like vim :terminal
|
-- Make nvim :terminal more like vim :terminal
|
||||||
vim.keymap.set('t', '<C-w>N', '<C-\\><C-n>', opts)
|
vim.keymap.set('t', '<C-w>N', '<C-\\><C-n>', opts)
|
||||||
@@ -50,3 +50,10 @@ vim.keymap.set('v', '<leader>rg', ":'<,'>Rg<CR>", opts)
|
|||||||
|
|
||||||
-- Mapping to toggle checkboxes
|
-- Mapping to toggle checkboxes
|
||||||
vim.keymap.set('n', '<leader><CR>', ':CheckboxToggle<CR>', opts)
|
vim.keymap.set('n', '<leader><CR>', ':CheckboxToggle<CR>', opts)
|
||||||
|
|
||||||
|
-- Format whole file using internal algorithm
|
||||||
|
vim.keymap.set('n', '<leader>gw', function()
|
||||||
|
local view = vim.fn.winsaveview()
|
||||||
|
vim.cmd('normal! gggwG')
|
||||||
|
vim.fn.winrestview(view)
|
||||||
|
end, { desc = 'Format whole file with gw' })
|
||||||
|
|||||||
@@ -78,7 +78,7 @@ vim.opt.splitbelow = true
|
|||||||
vim.opt.splitright = true
|
vim.opt.splitright = true
|
||||||
|
|
||||||
-- Use existing windows and tabs when jumping to errors
|
-- Use existing windows and tabs when jumping to errors
|
||||||
vim.opt.switchbuf = 'usetab'
|
vim.opt.switchbuf = 'usetab,uselast'
|
||||||
|
|
||||||
-- Automatically write changes to files
|
-- Automatically write changes to files
|
||||||
vim.opt.autowrite = true
|
vim.opt.autowrite = true
|
||||||
@@ -91,7 +91,7 @@ vim.opt.foldlevel = 20
|
|||||||
vim.opt.foldmethod = 'expr'
|
vim.opt.foldmethod = 'expr'
|
||||||
vim.opt.foldexpr = 'nvim_treesitter#foldexpr()'
|
vim.opt.foldexpr = 'nvim_treesitter#foldexpr()'
|
||||||
vim.opt.foldtext = ''
|
vim.opt.foldtext = ''
|
||||||
vim.opt.fillchars = 'fold: '
|
vim.opt.fillchars = { fold = ' ' }
|
||||||
|
|
||||||
-- Enable all mouse features
|
-- Enable all mouse features
|
||||||
vim.opt.mouse = 'a'
|
vim.opt.mouse = 'a'
|
||||||
|
|||||||
Reference in New Issue
Block a user