aboutsummaryrefslogtreecommitdiffstats
path: root/hm/soispha/conf/nvim/plgs/telescope/extensions/rooter/lua
diff options
context:
space:
mode:
authorSoispha <soispha@vhack.eu>2023-08-29 21:33:43 +0200
committerSoispha <soispha@vhack.eu>2023-08-29 21:33:43 +0200
commit3925f6ee04f09d7d09b7aff018812670a0e89492 (patch)
tree12642e7332ebb53153bef1bf5d5f811e3f19884b /hm/soispha/conf/nvim/plgs/telescope/extensions/rooter/lua
parentFeat(hm/conf/nvim/plgs/debugprint): Init (diff)
downloadnixos-config-3925f6ee04f09d7d09b7aff018812670a0e89492.zip
Refactor(hm/conf/nvim/plugins): Rename to `plgs` to safe commit msg space
Diffstat (limited to 'hm/soispha/conf/nvim/plgs/telescope/extensions/rooter/lua')
-rw-r--r--hm/soispha/conf/nvim/plgs/telescope/extensions/rooter/lua/rooter.lua84
1 files changed, 84 insertions, 0 deletions
diff --git a/hm/soispha/conf/nvim/plgs/telescope/extensions/rooter/lua/rooter.lua b/hm/soispha/conf/nvim/plgs/telescope/extensions/rooter/lua/rooter.lua
new file mode 100644
index 00000000..eaf68ecf
--- /dev/null
+++ b/hm/soispha/conf/nvim/plgs/telescope/extensions/rooter/lua/rooter.lua
@@ -0,0 +1,84 @@
+-- Taken from: https://github.com/desdic/telescope-rooter.nvim/blob/69423216c75a5f1f1477bbf8faf6b0dc8af04099/lua/telescope/_extensions/rooter.lua
+local has_telescope, telescope = pcall(require, "telescope")
+if not has_telescope then
+ error("This extension requires telescope.nvim")
+ return
+end
+
+local has_plenary, plenary = pcall(require, "plenary")
+if not has_plenary then
+ error("This extension requires plenary")
+ return
+end
+
+local log = plenary.log.new({ plugin = "telescope_rooter"; level = "info"; })
+
+-- TODO: expose this function
+local toggle = function(_)
+ vim.g["Telescope#rooter#enabled"] = not vim.g["Telescope#rooter#enabled"]
+ print("Telescope#rooter#enabled=" .. vim.inspect(vim.g["Telescope#rooter#enabled"]))
+end
+
+local config = { patterns = { ".git"; }; enable = true; debug = false; }
+
+-- default enabled
+vim.g["Telescope#rooter#enabled"] = vim.F.if_nil(config.enable, true)
+
+-- redefine log if debug enabled
+if vim.F.if_nil(config.debug, false) then
+ log = plenary.log.new({ plugin = "telescope_rooter"; level = "debug"; })
+end
+
+local group = vim.api.nvim_create_augroup("TelescopeRooter", { clear = true; })
+
+vim.api.nvim_create_autocmd({ "DirChangedPre"; }, {
+ callback = function()
+ if vim.g["Telescope#rooter#enabled"] ~= true then
+ return
+ end
+
+ if vim.g["Telescope#rooter#oldpwd"] == nil then
+ vim.g["Telescope#rooter#oldpwd"] = vim.loop.cwd()
+ log.debug("before " .. vim.inspect(vim.loop.cwd()))
+ end
+ end;
+ group = group;
+})
+
+vim.api.nvim_create_autocmd({ "BufEnter"; "BufWinEnter"; }, {
+ callback = function()
+ if vim.g["Telescope#rooter#enabled"] ~= true then
+ return
+ end
+
+ vim.schedule(function()
+ if vim.bo.filetype == "TelescopePrompt" then
+ local rootdir = vim.fs.dirname(vim.fs.find(config.patterns, { upward = true; })[1])
+ if rootdir ~= nil then
+ vim.api.nvim_set_current_dir(rootdir)
+ log.debug("changing dir to " .. rootdir)
+ end
+ end
+ end)
+ end;
+ group = group;
+})
+
+vim.api.nvim_create_autocmd({ "BufWinLeave"; }, {
+ callback = function()
+ if vim.g["Telescope#rooter#enabled"] ~= true then
+ return
+ end
+
+ vim.schedule(function()
+ if vim.bo.filetype ~= "TelescopePrompt" then
+ if vim.g["Telescope#rooter#oldpwd"] ~= nil then
+ log.debug("restoring " .. vim.g["Telescope#rooter#oldpwd"])
+ vim.api.nvim_set_current_dir(vim.g["Telescope#rooter#oldpwd"])
+ vim.g["Telescope#rooter#oldpwd"] = nil
+ end
+ end
+ end)
+ end;
+ group = group;
+})