summaryrefslogtreecommitdiffstats
path: root/.config/nvim/after/ftplugin/gitcommit.lua
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,
})