From 9d44f2c198d7bd5d347362c00c1afbc48a0c4140 Mon Sep 17 00:00:00 2001 From: "jakob.stendahl" Date: Wed, 19 Jun 2024 18:04:20 +0200 Subject: Simple merge request reviewing --- Common/nvim/colors/bw.vim | 17 ++----- Common/nvim/lua/helper_functions.lua | 86 ++++++++++++++++++++++-------------- 2 files changed, 57 insertions(+), 46 deletions(-) (limited to 'Common/nvim') diff --git a/Common/nvim/colors/bw.vim b/Common/nvim/colors/bw.vim index 309127d..7ac865c 100644 --- a/Common/nvim/colors/bw.vim +++ b/Common/nvim/colors/bw.vim @@ -45,14 +45,9 @@ hi SpellCap term=undercurl cterm=undercurl ctermfg=5 gui=undercurl guisp=Da hi SpellLocal term=undercurl cterm=undercurl ctermfg=5 gui=undercurl guisp=Green hi SpellRare term=undercurl cterm=undercurl ctermfg=5 gui=undercurl guisp=LightCyan -"hi DiffAdd ctermfg=2 guifg=White guibg=DarkGreen -"hi DiffChange ctermfg=94 guifg=White guibg=DarkYellow -"hi DiffDelete ctermfg=1 guifg=White guibg=DarkRed -"hi DiffText ctermfg=4 guifg=Blue -hi DiffAdd ctermfg=2 guifg=Green -hi DiffChange ctermfg=94 guifg=DarkYellow -hi DiffDelete ctermfg=1 guifg=Red -hi DiffText ctermfg=4 guifg=Blue +hi DiffAdd ctermfg=2 guibg=LightGreen +hi DiffDelete ctermfg=1 guibg=LightRed +hi DiffText ctermbg=94 guibg=LightBlue hi link Removed DiffDelete hi link Added DiffAdd @@ -65,14 +60,8 @@ hi link SpecialComment Comment hi ColorColumn ctermbg=240 guibg=LightGrey hi Underlined cterm=bold gui=bold - hi Error ctermbg=white ctermfg=red cterm=reverse gui=reverse hi Special cterm=italic gui=italic -" hi Identifier cterm=bold gui=bold -" hi Statement cterm=bold gui=bold -" hi Todo cterm=reverse gui=reverse -" hi Type cterm=bold,italic gui=bold,italic -" hi Constant cterm=bold hi Directory cterm=bold diff --git a/Common/nvim/lua/helper_functions.lua b/Common/nvim/lua/helper_functions.lua index 8ce5e73..7f2be82 100755 --- a/Common/nvim/lua/helper_functions.lua +++ b/Common/nvim/lua/helper_functions.lua @@ -54,28 +54,7 @@ vim.api.nvim_create_user_command('JoinLinesBT', JoinLinesBT, {bang=false, desc=' -- Strip trailing spaces vim.keymap.set('n', 'wt', [[:%s/\s\+$//e]]) --- Quick json formatting using jq -function JsonFormat(start_line, end_line) - if start_line == nil or end_line == nil then - if vim.fn.mode() == 'v' then - start_line, _, end_line, _ = unpack(vim.fn.getpos("'<"), 2, 5) - else - start_line, end_line = 1, vim.api.nvim_buf_line_count(0) - end - end - local lines = vim.api.nvim_buf_get_lines(0, start_line - 1, end_line, false) - local json_string = table.concat(lines, "\n") - local handle = io.popen("echo '" .. json_string .. "' | jq .", "r") - local result = handle:read("*a") - handle:close() - vim.api.nvim_buf_set_lines(0, start_line - 1, end_line, false, vim.fn.split(result, "\n")) -end -vim.api.nvim_create_user_command('JsonFormat', function(opts) - JsonFormat(opts.line1, opts.line2) -end, {range = true, desc = 'Format JSON'}) -vim.keymap.set('n', 'jq', JsonFormat, { noremap = true, silent = true }) -vim.keymap.set('v', 'jq', ':JsonFormat', { noremap = true, silent = true }) - +-- Set spelling languages function English() vim.opt.spell = true vim.opt.spelllang = "en_us" @@ -87,15 +66,6 @@ function Norsk() end vim.api.nvim_create_user_command('Norsk', Norsk, {bang=false, desc='Enables spellchecking for norsk bokmål'}) --- enable filetype and such -function auto() - vim.cmd [[ - filetype plugin on - filetype indent on - ]] -end -vim.api.nvim_create_user_command('A', auto, {bang=false, desc='Enable filetype plugin and indent'}) - -- Quick rerun of last command in terminal function rerun_last_command_in_any_terminal() local buffers = vim.api.nvim_list_bufs() @@ -166,6 +136,58 @@ nnoremap s :GitHistoryForLine vnoremap s :'<,'>GitHistoryForLine ]] +-- Compare git to revision +function GRevisionDiff() + local handle = io.popen("git diff --name-only $(git merge-base HEAD master)") + local files = handle:read("*a") + handle:close() + + files = vim.split(files, "\n") + vim.fn.setqflist({}) + for _, file in ipairs(files) do + if file ~= '' then + local handle = io.popen("git diff --stat HEAD master " .. file .. " | head -n 1 | awk -F '|' '{print $2}'") + local diffstat = handle:read("*a") + handle:close() + vim.fn.setqflist({}, 'a', { + title = 'GRevisionDiff: changed files', + items= {{filename = file, text = diffstat}} + }) + end + end + vim.cmd("copen") +end +vim.api.nvim_create_user_command('GRevisionDiff', GRevisionDiff, {bang=false, desc=''}) + +function close_existing_diff_windows() + local windows = vim.api.nvim_list_wins() + for _, win in ipairs(windows) do + local buf = vim.api.nvim_win_get_buf(win) + if vim.api.nvim_win_get_option(win, "diff") then + vim.api.nvim_win_close(win, true) + end + end +end + +function GRevisionDiffOpen() + vim.api.nvim_feedkeys(vim.api.nvim_replace_termcodes("", true, false, true), "n", true) + local qf_title = vim.fn.getqflist({title = 0}).title + if qf_title == 'GRevisionDiff: changed files' then + local filename = vim.fn.expand("") + close_existing_diff_windows() + vim.defer_fn(function() + vim.cmd("Gvdiffsplit master ") + end, 50) + end +end + +vim.cmd [[ +augroup QuickfixGRevisionDiff + autocmd! + autocmd FileType qf noremap :lua GRevisionDiffOpen() +augroup END +]] + -- Invert timestamp function invertNumberUnderCursor() local word = vim.fn.expand("") -- Get the word under the cursor @@ -192,6 +214,7 @@ vim.api.nvim_create_autocmd('TextYankPost', { end, }) +-- Insert a datetime timestamp in md function insert_date_time() local date_time = os.date("%d %H:%M") local insert_text = string.format("- **%s** - **", date_time) @@ -205,4 +228,3 @@ vim.api.nvim_create_user_command("InsertDateTime", insert_date_time, {}) -- Reminders for system clipboard register vim.api.nvim_set_keymap('v', 'y', [[:lua vim.api.nvim_echo({{"Use register '+' for system clipboard", "ErrorMsg"}}, false, {})]], {noremap = true, silent=false}) vim.api.nvim_set_keymap('n', 'y', [[:lua vim.api.nvim_echo({{"Use register '+' for system clipboard", "ErrorMsg"}}, false, {})]], {noremap = true, silent=false}) - -- cgit v1.2.3