hooks.lua 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. local M = {}
  2. local Log = require "lvim.core.log"
  3. local in_headless = #vim.api.nvim_list_uis() == 0
  4. local plugin_loader = require "lvim.plugin-loader"
  5. function M.run_pre_update()
  6. Log:debug "Starting pre-update hook"
  7. end
  8. function M.run_pre_reload()
  9. Log:debug "Starting pre-reload hook"
  10. end
  11. function M.run_on_packer_complete()
  12. Log:debug "Packer operation complete"
  13. vim.api.nvim_exec_autocmds("User", { pattern = "PackerComplete" })
  14. if M._reload_triggered then
  15. if not in_headless then
  16. vim.schedule(function()
  17. -- FIXME(kylo252): nvim-tree.lua/lua/nvim-tree/view.lua:442: Invalid window id
  18. -- pcall(vim.api.nvim_exec_autocmds, "ColorScheme", { pattern = "*" })
  19. pcall(vim.cmd.colorscheme, lvim.colorscheme)
  20. end)
  21. end
  22. Log:debug "Reloaded configuration"
  23. M._reload_triggered = nil
  24. end
  25. end
  26. function M.run_post_reload()
  27. Log:debug "Starting post-reload hook"
  28. M.reset_cache()
  29. M._reload_triggered = true
  30. end
  31. ---Reset any startup cache files used by Packer and Impatient
  32. ---It also forces regenerating any template ftplugin files
  33. ---Tip: Useful for clearing any outdated settings
  34. function M.reset_cache()
  35. plugin_loader.recompile()
  36. local lvim_modules = {}
  37. for module, _ in pairs(package.loaded) do
  38. if module:match "lvim.core" or module:match "lvim.lsp" then
  39. package.loaded[module] = nil
  40. table.insert(lvim_modules, module)
  41. end
  42. end
  43. Log:trace(string.format("Cache invalidated for core modules: { %s }", table.concat(lvim_modules, ", ")))
  44. require("lvim.lsp.templates").generate_templates()
  45. end
  46. function M.run_post_update()
  47. Log:debug "Starting post-update hook"
  48. if vim.fn.has "nvim-0.8" ~= 1 then
  49. local compat_tag = "1.1.4"
  50. vim.notify(
  51. "Please upgrade your Neovim base installation. Newer version of Lunarvim requires v0.7+",
  52. vim.log.levels.WARN
  53. )
  54. vim.wait(1000, function()
  55. return false
  56. end)
  57. local ret = reload("lvim.utils.git").switch_lvim_branch(compat_tag)
  58. if ret then
  59. vim.notify("Reverted to the last known compatible version: " .. compat_tag, vim.log.levels.WARN)
  60. end
  61. return
  62. end
  63. M.reset_cache()
  64. Log:debug "Syncing core plugins"
  65. plugin_loader.sync_core_plugins()
  66. if not in_headless then
  67. vim.schedule(function()
  68. if package.loaded["nvim-treesitter"] then
  69. vim.cmd [[ TSUpdateSync ]]
  70. end
  71. -- TODO: add a changelog
  72. vim.notify("Update complete", vim.log.levels.INFO)
  73. end)
  74. end
  75. end
  76. return M