Merge pull request #16 from kdheepak/kd/change-floating-window-persistence

This commit is contained in:
Dheepak Krishnamurthy
2020-07-18 17:15:39 -06:00
committed by GitHub

View File

@@ -2,7 +2,8 @@ vim = vim
local api = vim.api
local fn = vim.fn
FILE_BUFFER = nil
LAZYGIT_BUFFER = nil
LAZYGIT_LOADED = false
--- Strip leading and lagging whitespace
local function trim(str)
@@ -37,9 +38,10 @@ end
--- on_exit callback function to delete the open buffer when lazygit exits in a neovim terminal
local function on_exit(job_id, code, event)
if code == 0 then
-- delete terminal buffer
vim.cmd("silent! bdelete!")
FILE_BUFFER = nil
-- Close the window where the LAZYGIT_BUFFER is
vim.cmd("silent! :q")
LAZYGIT_BUFFER = nil
LAZYGIT_LOADED = false
end
end
@@ -53,9 +55,11 @@ end
--- Call lazygit
local function exec_lazygit_command(cmd)
cmd = git_editor_prefix(cmd)
-- ensure that the buffer is closed on exit
vim.fn.termopen(cmd, { on_exit = on_exit })
if LAZYGIT_LOADED == false then
cmd = git_editor_prefix(cmd)
-- ensure that the buffer is closed on exit
vim.fn.termopen(cmd, { on_exit = on_exit })
end
vim.cmd "startinsert"
end
@@ -111,20 +115,25 @@ local function open_floating_window()
vim.cmd 'set winhl=Normal:Floating'
-- create a unlisted scratch buffer
if FILE_BUFFER == nil then
FILE_BUFFER = api.nvim_create_buf(false, true)
if LAZYGIT_BUFFER == nil then
LAZYGIT_BUFFER = api.nvim_create_buf(false, true)
else
LAZYGIT_LOADED = true
end
-- create file window, enter the window, and use the options defined in opts
local file_window = api.nvim_open_win(FILE_BUFFER, true, opts)
local file_window = api.nvim_open_win(LAZYGIT_BUFFER, true, opts)
vim.bo[FILE_BUFFER].filetype = 'lazygit'
vim.bo[LAZYGIT_BUFFER].filetype = 'lazygit'
vim.cmd('setlocal bufhidden=hide')
vim.cmd('setlocal nocursorcolumn')
vim.cmd('set winblend=' .. vim.g.lazygit_floating_window_winblend)
-- use autocommand to ensure that the border_buffer closes at the same time as the main buffer
local cmd = [[autocmd WinLeave <buffer> silent! execute 'silent bdelete! %s %s']]
vim.cmd(cmd:format(FILE_BUFFER, border_buffer))
local cmd = [[autocmd WinLeave <buffer> silent! execute 'hide']]
vim.cmd(cmd)
local cmd = [[autocmd WinLeave <buffer> silent! execute 'silent bdelete! %s']]
vim.cmd(cmd:format(border_buffer))
end
--- :LazyGit entry point