Skip to content

Commit

Permalink
refactor: make VirtualIndent start_watch_org_indent idempotent
Browse files Browse the repository at this point in the history
This ensures we can call `start_watch_org_indent` as much as we want
without starting a bunch of timers in the background.

This enforces the use of `start_watch_org_indent` and `stop_watch_org_indent` for managing the timer.
  • Loading branch information
PriceHiller committed Feb 7, 2024
1 parent 7e364c7 commit 84a8c6f
Showing 1 changed file with 21 additions and 15 deletions.
36 changes: 21 additions & 15 deletions lua/orgmode/ui/virtual_indent.lua
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
---@field private _attached boolean Whether or not VirtualIndent is attached for its buffer
---@field private _bufnrs {integer: boolean} Buffers with VirtualIndent attached
---@field private _timer uv_timer_t Timer used for tracking `org_indent_mode`
---@field private _watcher_running boolean Whether or not VirtualIndent is reacting to `vim.borg_indent_mode`
local VirtualIndent = {
_ns_id = vim.api.nvim_create_namespace('orgmode.ui.indent'),
_bufnrs = {},
Expand All @@ -30,6 +31,7 @@ function VirtualIndent:new(bufnr)
new._headline_lib = require('orgmode.treesitter.headline')
new._attached = false
VirtualIndent._bufnrs[new._bufnr] = new
new._watcher_running = false
new._timer = vim.uv.new_timer()
return new
end
Expand Down Expand Up @@ -90,27 +92,31 @@ function VirtualIndent:set_indent(start_line, end_line, ignore_ts)
end
end

--- Begins a timer to check `vim.b.org_indent_mode` and correctly attach or detatch VirtualIndent as
--- necessary
--- Begins a timer to check `vim.b.org_indent_mode` if `vim.b.org_indent_mode` is not already being
--- monitored
function VirtualIndent:start_watch_org_indent()
self._timer:start(
50,
50,
vim.schedule_wrap(function()
local success, indent_mode_enabled = pcall(vim.api.nvim_buf_get_var, self._bufnr, 'org_indent_mode')
if success and indent_mode_enabled then
if not self._attached then
self:attach()
if not self._watcher_running then
self._watcher_running = true
self._timer:start(
50,
50,
vim.schedule_wrap(function()
local success, indent_mode_enabled = pcall(vim.api.nvim_buf_get_var, self._bufnr, 'org_indent_mode')
if success and indent_mode_enabled then
if not self._attached then
self:attach()
end
elseif self._attached then
self:detach()
end
elseif self._attached then
self:detach()
end
end)
)
end)
)
end
end

--- Stops the current VirtualIndent instance from reacting to changes in `vim.b.org_indent_mode`
function VirtualIndent:stop_watch_org_indent()
self._watcher_running = false
self._timer:stop()
end

Expand Down

0 comments on commit 84a8c6f

Please sign in to comment.