Compare commits

..

4 Commits

Author SHA1 Message Date
Ori Perry
d3ff7eb296
Merge aa93f4d7d10d19edd78128ef5aa19c14770fe2f0 into d350db2449da40df003c40d440f909d74e2d4e70 2025-04-18 17:16:39 +00:00
orip
aa93f4d7d1 Switch telescope for snacks.nvim 2025-04-18 20:16:34 +03:00
orip
a788d7f29d Update the github workflow 2025-04-18 19:47:13 +03:00
orip
4111f9eec5 Collapse small functions when formatting
This would allow to write more concise and easy to understands keybinds in
the following commit
2025-04-18 19:45:50 +03:00
5 changed files with 31 additions and 140 deletions

View File

@ -9,11 +9,11 @@ jobs:
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- name: Checkout Code - name: Checkout Code
uses: actions/checkout@v2 uses: actions/checkout@v4
with: with:
ref: ${{ github.event.pull_request.head.sha }} ref: ${{ github.event.pull_request.head.sha }}
- name: Stylua Check - name: Stylua Check
uses: JohnnyMorganz/stylua-action@v3 uses: JohnnyMorganz/stylua-action@v4
with: with:
token: ${{ secrets.GITHUB_TOKEN }} token: ${{ secrets.GITHUB_TOKEN }}
version: latest version: latest

View File

@ -4,3 +4,4 @@ indent_type = "Spaces"
indent_width = 2 indent_width = 2
quote_style = "AutoPreferSingle" quote_style = "AutoPreferSingle"
call_parentheses = "None" call_parentheses = "None"
collapse_simple_statement = "FunctionOnly"

126
init.lua
View File

@ -114,9 +114,7 @@ vim.opt.showmode = false
-- Schedule the setting after `UiEnter` because it can increase startup-time. -- Schedule the setting after `UiEnter` because it can increase startup-time.
-- Remove this option if you want your OS clipboard to remain independent. -- Remove this option if you want your OS clipboard to remain independent.
-- See `:help 'clipboard'` -- See `:help 'clipboard'`
vim.schedule(function() vim.schedule(function() vim.opt.clipboard = 'unnamedplus' end)
vim.opt.clipboard = 'unnamedplus'
end)
-- Enable break indent -- Enable break indent
vim.opt.breakindent = true vim.opt.breakindent = true
@ -209,9 +207,7 @@ vim.keymap.set('n', '<C-k>', '<C-w><C-k>', { desc = 'Move focus to the upper win
vim.api.nvim_create_autocmd('TextYankPost', { vim.api.nvim_create_autocmd('TextYankPost', {
desc = 'Highlight when yanking (copying) text', desc = 'Highlight when yanking (copying) text',
group = vim.api.nvim_create_augroup('kickstart-highlight-yank', { clear = true }), group = vim.api.nvim_create_augroup('kickstart-highlight-yank', { clear = true }),
callback = function() callback = function() vim.highlight.on_yank() end,
vim.highlight.on_yank()
end,
}) })
-- [[ Install `lazy.nvim` plugin manager ]] -- [[ Install `lazy.nvim` plugin manager ]]
@ -382,99 +378,20 @@ require('lazy').setup({
-- See `:help snacks-pickers-sources` -- See `:help snacks-pickers-sources`
keys = { keys = {
{ { '<leader>sh', function() Snacks.picker.help() end, desc = '[S]earch [H]elp' },
'<leader>sh', { '<leader>sk', function() Snacks.picker.keymaps() end, desc = '[S]earch [K]eymaps' },
function() { '<leader>sf', function() Snacks.picker.smart() end, desc = '[S]earch [F]iles' },
Snacks.picker.help() { '<leader>ss', function() Snacks.picker.pickers() end, desc = '[S]earch [S]elect Snacks' },
end, { '<leader>sw', function() Snacks.picker.grep_word() end, desc = '[S]earch current [W]ord', mode = { 'n', 'x' } },
desc = '[S]earch [H]elp', { '<leader>sg', function() Snacks.picker.grep() end, desc = '[S]earch by [G]rep' },
}, { '<leader>sd', function() Snacks.picker.diagnostics() end, desc = '[S]earch [D]iagnostics' },
{ { '<leader>sr', function() Snacks.picker.resume() end, desc = '[S]earch [R]esume' },
'<leader>sk', { '<leader>s.', function() Snacks.picker.recent() end, desc = '[S]earch Recent Files ("." for repeat)' },
function() { '<leader><leader>', function() Snacks.picker.buffers() end, desc = '[ ] Find existing buffers' },
Snacks.picker.keymaps() { '<leader>/', function() Snacks.picker.lines {} end, desc = '[/] Fuzzily search in current buffer' },
end, { '<leader>s/', function() Snacks.picker.grep_buffers() end, desc = '[S]earch [/] in Open Files' },
desc = '[S]earch [K]eymaps',
},
{
'<leader>sf',
function()
Snacks.picker.smart()
end,
desc = '[S]earch [F]iles',
},
{
'<leader>ss',
function()
Snacks.picker.pickers()
end,
desc = '[S]earch [S]elect Snacks',
},
{
'<leader>sw',
function()
Snacks.picker.grep_word()
end,
desc = '[S]earch current [W]ord',
mode = { 'n', 'x' },
},
{
'<leader>sg',
function()
Snacks.picker.grep()
end,
desc = '[S]earch by [G]rep',
},
{
'<leader>sd',
function()
Snacks.picker.diagnostics()
end,
desc = '[S]earch [D]iagnostics',
},
{
'<leader>sr',
function()
Snacks.picker.resume()
end,
desc = '[S]earch [R]esume',
},
{
'<leader>s.',
function()
Snacks.picker.recent()
end,
desc = '[S]earch Recent Files ("." for repeat)',
},
{
'<leader><leader>',
function()
Snacks.picker.buffers()
end,
desc = '[ ] Find existing buffers',
},
{
'<leader>/',
function()
Snacks.picker.lines {}
end,
desc = '[/] Fuzzily search in current buffer',
},
{
'<leader>s/',
function()
Snacks.picker.grep_buffers()
end,
desc = '[S]earch [/] in Open Files',
},
-- Shortcut for searching your Neovim configuration files -- Shortcut for searching your Neovim configuration files
{ { '<leader>sn', function() Snacks.picker.files { cwd = vim.fn.stdpath 'config' } end, desc = '[S]earch [N]eovim files' },
'<leader>sn',
function()
Snacks.picker.files { cwd = vim.fn.stdpath 'config' }
end,
desc = '[S]earch [N]eovim files',
},
}, },
}, },
@ -488,7 +405,6 @@ require('lazy').setup({
library = { library = {
-- Load luvit types when the `vim.uv` word is found -- Load luvit types when the `vim.uv` word is found
{ path = '${3rd}/luv/library', words = { 'vim%.uv' } }, { path = '${3rd}/luv/library', words = { 'vim%.uv' } },
{ path = 'snacks.nvim', words = { 'Snacks' } },
}, },
}, },
}, },
@ -635,9 +551,7 @@ require('lazy').setup({
-- --
-- This may be unwanted, since they displace some of your code -- This may be unwanted, since they displace some of your code
if client and client_supports_method(client, vim.lsp.protocol.Methods.textDocument_inlayHint, event.buf) then if client and client_supports_method(client, vim.lsp.protocol.Methods.textDocument_inlayHint, event.buf) then
map('<leader>th', function() map('<leader>th', function() vim.lsp.inlay_hint.enable(not vim.lsp.inlay_hint.is_enabled { bufnr = event.buf }) end, '[T]oggle Inlay [H]ints')
vim.lsp.inlay_hint.enable(not vim.lsp.inlay_hint.is_enabled { bufnr = event.buf })
end, '[T]oggle Inlay [H]ints')
end end
end, end,
}) })
@ -759,9 +673,7 @@ require('lazy').setup({
keys = { keys = {
{ {
'<leader>f', '<leader>f',
function() function() require('conform').format { async = true, lsp_format = 'fallback' } end,
require('conform').format { async = true, lsp_format = 'fallback' }
end,
mode = '', mode = '',
desc = '[F]ormat buffer', desc = '[F]ormat buffer',
}, },
@ -946,9 +858,7 @@ require('lazy').setup({
-- default behavior. For example, here we set the section for -- default behavior. For example, here we set the section for
-- cursor location to LINE:COLUMN -- cursor location to LINE:COLUMN
---@diagnostic disable-next-line: duplicate-set-field ---@diagnostic disable-next-line: duplicate-set-field
statusline.section_location = function() statusline.section_location = function() return '%2l:%-2v' end
return '%2l:%-2v'
end
-- ... and there is more! -- ... and there is more!
-- Check out: https://github.com/echasnovski/mini.nvim -- Check out: https://github.com/echasnovski/mini.nvim

View File

@ -28,52 +28,38 @@ return {
-- Basic debugging keymaps, feel free to change to your liking! -- Basic debugging keymaps, feel free to change to your liking!
{ {
'<F5>', '<F5>',
function() function() require('dap').continue() end,
require('dap').continue()
end,
desc = 'Debug: Start/Continue', desc = 'Debug: Start/Continue',
}, },
{ {
'<F1>', '<F1>',
function() function() require('dap').step_into() end,
require('dap').step_into()
end,
desc = 'Debug: Step Into', desc = 'Debug: Step Into',
}, },
{ {
'<F2>', '<F2>',
function() function() require('dap').step_over() end,
require('dap').step_over()
end,
desc = 'Debug: Step Over', desc = 'Debug: Step Over',
}, },
{ {
'<F3>', '<F3>',
function() function() require('dap').step_out() end,
require('dap').step_out()
end,
desc = 'Debug: Step Out', desc = 'Debug: Step Out',
}, },
{ {
'<leader>b', '<leader>b',
function() function() require('dap').toggle_breakpoint() end,
require('dap').toggle_breakpoint()
end,
desc = 'Debug: Toggle Breakpoint', desc = 'Debug: Toggle Breakpoint',
}, },
{ {
'<leader>B', '<leader>B',
function() function() require('dap').set_breakpoint(vim.fn.input 'Breakpoint condition: ') end,
require('dap').set_breakpoint(vim.fn.input 'Breakpoint condition: ')
end,
desc = 'Debug: Set Breakpoint', desc = 'Debug: Set Breakpoint',
}, },
-- Toggle to see last session result. Without this, you can't see session output in case of unhandled exception. -- Toggle to see last session result. Without this, you can't see session output in case of unhandled exception.
{ {
'<F7>', '<F7>',
function() function() require('dapui').toggle() end,
require('dapui').toggle()
end,
desc = 'Debug: See last session result.', desc = 'Debug: See last session result.',
}, },
}, },

View File

@ -34,12 +34,8 @@ return {
-- Actions -- Actions
-- visual mode -- visual mode
map('v', '<leader>hs', function() map('v', '<leader>hs', function() gitsigns.stage_hunk { vim.fn.line '.', vim.fn.line 'v' } end, { desc = 'git [s]tage hunk' })
gitsigns.stage_hunk { vim.fn.line '.', vim.fn.line 'v' } map('v', '<leader>hr', function() gitsigns.reset_hunk { vim.fn.line '.', vim.fn.line 'v' } end, { desc = 'git [r]eset hunk' })
end, { desc = 'git [s]tage hunk' })
map('v', '<leader>hr', function()
gitsigns.reset_hunk { vim.fn.line '.', vim.fn.line 'v' }
end, { desc = 'git [r]eset hunk' })
-- normal mode -- normal mode
map('n', '<leader>hs', gitsigns.stage_hunk, { desc = 'git [s]tage hunk' }) map('n', '<leader>hs', gitsigns.stage_hunk, { desc = 'git [s]tage hunk' })
map('n', '<leader>hr', gitsigns.reset_hunk, { desc = 'git [r]eset hunk' }) map('n', '<leader>hr', gitsigns.reset_hunk, { desc = 'git [r]eset hunk' })
@ -49,9 +45,7 @@ return {
map('n', '<leader>hp', gitsigns.preview_hunk, { desc = 'git [p]review hunk' }) map('n', '<leader>hp', gitsigns.preview_hunk, { desc = 'git [p]review hunk' })
map('n', '<leader>hb', gitsigns.blame_line, { desc = 'git [b]lame line' }) map('n', '<leader>hb', gitsigns.blame_line, { desc = 'git [b]lame line' })
map('n', '<leader>hd', gitsigns.diffthis, { desc = 'git [d]iff against index' }) map('n', '<leader>hd', gitsigns.diffthis, { desc = 'git [d]iff against index' })
map('n', '<leader>hD', function() map('n', '<leader>hD', function() gitsigns.diffthis '@' end, { desc = 'git [D]iff against last commit' })
gitsigns.diffthis '@'
end, { desc = 'git [D]iff against last commit' })
-- Toggles -- Toggles
map('n', '<leader>tb', gitsigns.toggle_current_line_blame, { desc = '[T]oggle git show [b]lame line' }) map('n', '<leader>tb', gitsigns.toggle_current_line_blame, { desc = '[T]oggle git show [b]lame line' })
map('n', '<leader>tD', gitsigns.preview_hunk_inline, { desc = '[T]oggle git show [D]eleted' }) map('n', '<leader>tD', gitsigns.preview_hunk_inline, { desc = '[T]oggle git show [D]eleted' })