Skip to content

Commit

Permalink
Fix idempotency issue
Browse files Browse the repository at this point in the history
It turns out that most of these come from the `_DEFAULTS` pattern. This
is because of the following:
original state:
```lua
tbl = { _DEFAULTS = ... }
```
after configuration with empty table, `tbl = vim.tbl_extend(tbl._DEFAULTS, {})`
which practically replaces `tbl` by `tbl._DEFAULTS`:
```lua
tbl = { ... }
```
after this, the next call to `vim.tbl_extend(tbl._DEFAULTS, {})` fails, as
`tbl._DEFAULTS` is nil.

The solution to this is to just call `vim.tbl_extend(tbl, ...)` and store the
defaults in `tbl` itself. The `._DEFAULTS` field can be preserved by copying to
it after initialization.

Also `command` has been replaced with `command!` in vimscript and
`autocmd`s have been wrapped in an `augroup` which resets its state each
call. This is also common practice that avoids duplicate autocommands.

Fixes Julian#145
  • Loading branch information
4e554c4c committed Sep 7, 2022
1 parent 9b7445e commit b02b15f
Show file tree
Hide file tree
Showing 5 changed files with 68 additions and 65 deletions.
10 changes: 5 additions & 5 deletions lua/lean/commands.lua
Original file line number Diff line number Diff line change
Expand Up @@ -116,11 +116,11 @@ end

function commands.enable()
vim.cmd[[
command LeanPlainGoal :lua require'lean.commands'.show_goal(false)
command LeanPlainTermGoal :lua require'lean.commands'.show_term_goal(false)
command LeanGoal :lua require'lean.commands'.show_goal()
command LeanTermGoal :lua require'lean.commands'.show_term_goal()
command LeanLineDiagnostics :lua require'lean.commands'.show_line_diagnostics()
command! LeanPlainGoal :lua require'lean.commands'.show_goal(false)
command! LeanPlainTermGoal :lua require'lean.commands'.show_term_goal(false)
command! LeanGoal :lua require'lean.commands'.show_goal()
command! LeanTermGoal :lua require'lean.commands'.show_term_goal()
command! LeanLineDiagnostics :lua require'lean.commands'.show_line_diagnostics()
]]
end

Expand Down
2 changes: 1 addition & 1 deletion lua/lean/ft.lua
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ function ft.enable(opts)
-- this means we have to manage it
global_default_managed = true
end
options= vim.tbl_extend("force", options._DEFAULTS, opts)
options= vim.tbl_extend("force", options, opts)
if global_default_managed then
lean_nvim_default_filetype = options.default
end
Expand Down
58 changes: 29 additions & 29 deletions lua/lean/infoview.lua
Original file line number Diff line number Diff line change
Expand Up @@ -20,35 +20,35 @@ local infoview = {
debug = false,
}
local options = {
_DEFAULTS = {
width = 50,
height = 20,
horizontal_position = 'bottom',
separate_tab = false,

autoopen = true,
autopause = false,
indicators = "auto",
lean3 = { show_filter = true, mouse_events = false },
show_processing = true,
show_no_info_message = false,
use_widgets = true,

mappings = {
['K'] = 'click',
['<CR>'] = 'click',
['gd'] = 'go_to_def',
['gD'] = 'go_to_decl',
['gy'] = 'go_to_type',
['I'] = 'mouse_enter',
['i'] = 'mouse_leave',
['<Esc>'] = 'clear_all',
['C'] = 'clear_all',
['<LocalLeader><Tab>'] = 'goto_last_window',
}
width = 50,
height = 20,
horizontal_position = 'bottom',
separate_tab = false,

autoopen = true,
autopause = false,
indicators = "auto",
lean3 = { show_filter = true, mouse_events = false },
show_processing = true,
show_no_info_message = false,
use_widgets = true,

mappings = {
['K'] = 'click',
['<CR>'] = 'click',
['gd'] = 'go_to_def',
['gD'] = 'go_to_decl',
['gy'] = 'go_to_type',
['I'] = 'mouse_enter',
['i'] = 'mouse_leave',
['<Esc>'] = 'clear_all',
['C'] = 'clear_all',
['<LocalLeader><Tab>'] = 'goto_last_window',
}
}

options._DEFAULTS = vim.deepcopy(options)

--- An individual pin.
---@class Pin
---@field id string @a label to identify the pin
Expand Down Expand Up @@ -1039,13 +1039,13 @@ end

--- Enable and open the infoview across all Lean buffers.
function infoview.enable(opts)
options = vim.tbl_extend("force", options._DEFAULTS, opts)
options = vim.tbl_extend("force", options, opts)
infoview.mappings = options.mappings
infoview.enabled = true
infoview.set_autoopen(options.autoopen)
set_augroup("LeanInfoviewInit", [[
autocmd FileType lean3 lua require'lean.infoview'.make_buffer_focusable(vim.fn.expand('<afile>'))
autocmd FileType lean lua require'lean.infoview'.make_buffer_focusable(vim.fn.expand('<afile>'))
autocmd! FileType lean3 lua require'lean.infoview'.make_buffer_focusable(vim.fn.expand('<afile>'))
autocmd! FileType lean lua require'lean.infoview'.make_buffer_focusable(vim.fn.expand('<afile>'))
]])
end

Expand Down
46 changes: 24 additions & 22 deletions lua/lean/init.lua
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,6 @@ function lean.setup(opts)

opts.infoview = opts.infoview or {}
require'lean.infoview'.enable(opts.infoview)

require'lean.commands'.enable()

opts.lsp3 = opts.lsp3 or {}
Expand All @@ -64,31 +63,34 @@ function lean.setup(opts)
if opts.stderr.enable ~= false then require'lean.stderr'.enable(opts.stderr or {}) end

vim.cmd[[
command LeanRestartFile :lua require'lean.lsp'.restart_file()
command LeanRefreshFileDependencies :lua require'lean.lsp'.restart_file()
command LeanInfoviewToggle :lua require'lean.infoview'.toggle()
command LeanInfoviewPinTogglePause :lua require'lean.infoview'.pin_toggle_pause()
command LeanInfoviewAddPin :lua require'lean.infoview'.add_pin()
command LeanInfoviewClearPins :lua require'lean.infoview'.clear_pins()
command LeanInfoviewSetDiffPin :lua require'lean.infoview'.set_diff_pin()
command LeanInfoviewClearDiffPin :lua require'lean.infoview'.clear_diff_pin()
command LeanInfoviewToggleAutoDiffPin :lua require'lean.infoview'.toggle_auto_diff_pin(true)
command LeanInfoviewToggleNoClearAutoDiffPin :lua require'lean.infoview'.toggle_auto_diff_pin(false)
command LeanInfoviewEnableWidgets :lua require'lean.infoview'.enable_widgets()
command LeanInfoviewDisableWidgets :lua require'lean.infoview'.disable_widgets()
command LeanGotoInfoview :lua require'lean.infoview'.go_to()
command LeanAbbreviationsReverseLookup :lua require'lean.abbreviations'.show_reverse_lookup()
command LeanSorryFill :lua require'lean.sorry'.fill()
command LeanTryThis :lua require'lean.trythis'.swap()
command! LeanRestartFile :lua require'lean.lsp'.restart_file()
command! LeanRefreshFileDependencies :lua require'lean.lsp'.restart_file()
command! LeanInfoviewToggle :lua require'lean.infoview'.toggle()
command! LeanInfoviewPinTogglePause :lua require'lean.infoview'.pin_toggle_pause()
command! LeanInfoviewAddPin :lua require'lean.infoview'.add_pin()
command! LeanInfoviewClearPins :lua require'lean.infoview'.clear_pins()
command! LeanInfoviewSetDiffPin :lua require'lean.infoview'.set_diff_pin()
command! LeanInfoviewClearDiffPin :lua require'lean.infoview'.clear_diff_pin()
command! LeanInfoviewToggleAutoDiffPin :lua require'lean.infoview'.toggle_auto_diff_pin(true)
command! LeanInfoviewToggleNoClearAutoDiffPin :lua require'lean.infoview'.toggle_auto_diff_pin(false)
command! LeanInfoviewEnableWidgets :lua require'lean.infoview'.enable_widgets()
command! LeanInfoviewDisableWidgets :lua require'lean.infoview'.disable_widgets()
command! LeanGotoInfoview :lua require'lean.infoview'.go_to()
command! LeanAbbreviationsReverseLookup :lua require'lean.abbreviations'.show_reverse_lookup()
command! LeanSorryFill :lua require'lean.sorry'.fill()
command! LeanTryThis :lua require'lean.trythis'.swap()
]]

if opts.mappings == true then
vim.cmd[[
autocmd FileType lean3 lua require'lean'.use_suggested_mappings(true)
autocmd FileType lean lua require'lean'.use_suggested_mappings(true)
augroup lean_nvim_mappings
autocmd!
autocmd FileType lean3 lua require'lean'.use_suggested_mappings(true)
autocmd FileType lean lua require'lean'.use_suggested_mappings(true)
augroup END
]]
end

Expand Down
17 changes: 9 additions & 8 deletions lua/lean/progress_bars.lua
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
local progress = require('lean.progress')

local M = {}
local options = { _DEFAULTS = { priority = 10, character = '' } }
local progress_bars = {}
local options = { priority = 10, character = '' }
options._DEFAULTS = vim.deepcopy(options)

local sign_group_name = 'leanSignProgress'
local sign_name = 'leanSignProgress'
Expand Down Expand Up @@ -41,8 +42,8 @@ end
-- Table from bufnr to timer object.
local timers = {}

function M.update(params)
if not M.enabled then return end
function progress_bars.update(params)
if not progress_bars.enabled then return end
-- TODO FIXME can potentially create new buffer
local bufnr = vim.uri_to_bufnr(params.textDocument.uri)

Expand All @@ -54,15 +55,15 @@ function M.update(params)
end
end

function M.enable(opts)
options = vim.tbl_extend("force", options._DEFAULTS, opts)
function progress_bars.enable(opts)
options = vim.tbl_extend("force", options, opts)

vim.fn.sign_define(sign_name, {
text = options.character,
texthl = 'leanSignProgress',
})
vim.cmd[[hi def leanSignProgress guifg=orange ctermfg=215]]
M.enabled = true
progress_bars.enabled = true
end

return M
return progress_bars

0 comments on commit b02b15f

Please sign in to comment.