blob: 0f97d93d798dd46bd87f907ee13aeb37ca322eca (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
vim.opt_local.textwidth = vim.g.dotfiles.textwidth.gitcommit -- gw wraps at this value
vim.opt_local.colorcolumn = "+1" -- Highlight one column after 'textwidth'
vim.opt_local.tabstop = 2 -- CommonMark expects two spaces for indentation
vim.opt_local.shiftwidth = 0
vim.opt_local.softtabstop = -1
vim.opt_local.expandtab = true -- Change tabs to spaces
vim.opt_local.spelllang = "en_us"
vim.opt_local.complete = {
"w", -- other windows
".", -- current buffer
}
vim.api.nvim_create_autocmd("BufWinEnter", {
desc = "Show cached git diff",
group = vim.g.dotfiles.augroup,
buffer = 0,
callback = function()
local MIN_COL_FOR_VERTICAL_SPLIT = 200
local vert_split = vim.o.columns >= MIN_COL_FOR_VERTICAL_SPLIT
local gitcommit_window = vim.api.nvim_get_current_win()
-- Open cached diff window (see `:help ft-gitcommit-plugin`)
vim.cmd.DiffGitCached()
vim.opt_local.winfixwidth = false
vim.opt_local.winfixheight = false
if vert_split then
vim.cmd.wincmd("L")
else
vim.cmd.wincmd("J")
end
-- Enable English spell check in the original window
-- If `'spell'` is set before `:DiffGitCached` it propagates to the cached diff window (that we don't want)
vim.api.nvim_set_option_value("spell", true, { win = gitcommit_window })
-- The current window is the diff window
vim.bo.filetype = "diff"
vim.opt_local.foldenable = false
end,
})
|