hooks.lua 1.7 KB

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