local M = {} local plugin_loader = require "lvim.plugin-loader" local Log = require "lvim.core.log" local in_headless = #vim.api.nvim_list_uis() == 0 function M.run_pre_update() Log:debug "Starting pre-update hook" _G.__luacache.clear_cache() vim.cmd "LspStop" end ---Reset any startup cache files used by Packer and Impatient ---It also forces regenerating any template ftplugin files ---Tip: Useful for clearing any outdated settings function M.reset_cache() _G.__luacache.clear_cache() require("lvim.plugin-loader").recompile() package.loaded["lvim.lsp.templates"] = nil Log:debug "Re-generatring ftplugin template files" require("lvim.lsp.templates").generate_templates() end function M.run_post_update() Log:debug "Starting post-update hook" Log:debug "Re-generatring ftplugin template files" package.loaded["lvim.lsp.templates"] = nil require("lvim.lsp.templates").generate_templates() Log:debug "Updating core plugins" plugin_loader:sync_core_plugins() if not in_headless then vim.schedule(function() -- TODO: add a changelog vim.notify("Update complete", vim.log.levels.INFO) vim.cmd "LspRestart" end) end end return M