hooks.lua 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. local M = {}
  2. local Log = require "lvim.core.log"
  3. local in_headless = #vim.api.nvim_list_uis() == 0
  4. function M.run_pre_update()
  5. Log:debug "Starting pre-update hook"
  6. end
  7. function M.run_pre_reload()
  8. Log:debug "Starting pre-reload hook"
  9. end
  10. function M.run_on_packer_complete()
  11. -- manually trigger event to fix colors
  12. vim.cmd [[ doautocmd ColorScheme ]]
  13. Log:info "Reloaded configuration"
  14. end
  15. function M.run_post_reload()
  16. Log:debug "Starting post-reload hook"
  17. require("lvim.plugin-loader").ensure_installed()
  18. M.reset_cache()
  19. end
  20. ---Reset any startup cache files used by Packer and Impatient
  21. ---It also forces regenerating any template ftplugin files
  22. ---Tip: Useful for clearing any outdated settings
  23. function M.reset_cache()
  24. local impatient = _G.__luacache
  25. if impatient then
  26. impatient.clear_cache()
  27. end
  28. local lvim_modules = {}
  29. for module, _ in pairs(package.loaded) do
  30. if module:match "lvim.core" or module:match "lvim.lsp" then
  31. package.loaded[module] = nil
  32. table.insert(lvim_modules, module)
  33. end
  34. end
  35. Log:trace(string.format("Cache invalidated for core modules: { %s }", table.concat(lvim_modules, ", ")))
  36. require("lvim.lsp.templates").generate_templates()
  37. end
  38. function M.run_post_update()
  39. Log:debug "Starting post-update hook"
  40. M.reset_cache()
  41. Log:debug "Updating core plugins"
  42. require("lvim.plugin-loader").ensure_installed()
  43. if not in_headless then
  44. vim.schedule(function()
  45. if package.loaded["nvim-treesitter"] then
  46. vim.cmd [[ TSUpdateSync ]]
  47. end
  48. -- TODO: add a changelog
  49. vim.notify("Update complete", vim.log.levels.INFO)
  50. end)
  51. end
  52. end
  53. return M