bootstrap.lua 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. local M = {}
  2. if vim.fn.has "nvim-0.6.1" ~= 1 then
  3. vim.notify("Please upgrade your Neovim base installation. Lunarvim requires v0.6.1+", vim.log.levels.WARN)
  4. vim.wait(5000, function()
  5. return false
  6. end)
  7. vim.cmd "cquit"
  8. end
  9. local uv = vim.loop
  10. local path_sep = uv.os_uname().version:match "Windows" and "\\" or "/"
  11. local in_headless = #vim.api.nvim_list_uis() == 0
  12. ---Join path segments that were passed as input
  13. ---@return string
  14. function _G.join_paths(...)
  15. local result = table.concat({ ... }, path_sep)
  16. return result
  17. end
  18. ---Require a module in protected mode without relying on its cached value
  19. ---@param module string
  20. ---@return any
  21. function _G.require_clean(module)
  22. package.loaded[module] = nil
  23. _G[module] = nil
  24. local _, requested = pcall(require, module)
  25. return requested
  26. end
  27. ---Get the full path to `$LUNARVIM_RUNTIME_DIR`
  28. ---@return string
  29. function _G.get_runtime_dir()
  30. local lvim_runtime_dir = os.getenv "LUNARVIM_RUNTIME_DIR"
  31. if not lvim_runtime_dir then
  32. -- when nvim is used directly
  33. return vim.fn.stdpath "data"
  34. end
  35. return lvim_runtime_dir
  36. end
  37. ---Get the full path to `$LUNARVIM_CONFIG_DIR`
  38. ---@return string
  39. function _G.get_config_dir()
  40. local lvim_config_dir = os.getenv "LUNARVIM_CONFIG_DIR"
  41. if not lvim_config_dir then
  42. return vim.fn.stdpath "config"
  43. end
  44. return lvim_config_dir
  45. end
  46. ---Get the full path to `$LUNARVIM_CACHE_DIR`
  47. ---@return string
  48. function _G.get_cache_dir()
  49. local lvim_cache_dir = os.getenv "LUNARVIM_CACHE_DIR"
  50. if not lvim_cache_dir then
  51. return vim.fn.stdpath "cache"
  52. end
  53. return lvim_cache_dir
  54. end
  55. ---Initialize the `&runtimepath` variables and prepare for startup
  56. ---@return table
  57. function M:init(base_dir)
  58. self.runtime_dir = get_runtime_dir()
  59. self.config_dir = get_config_dir()
  60. self.cache_dir = get_cache_dir()
  61. self.pack_dir = join_paths(self.runtime_dir, "site", "pack")
  62. self.packer_install_dir = join_paths(self.runtime_dir, "site", "pack", "packer", "start", "packer.nvim")
  63. self.packer_cache_path = join_paths(self.config_dir, "plugin", "packer_compiled.lua")
  64. ---Get the full path to LunarVim's base directory
  65. ---@return string
  66. function _G.get_lvim_base_dir()
  67. return base_dir
  68. end
  69. if os.getenv "LUNARVIM_RUNTIME_DIR" then
  70. -- vim.opt.rtp:append(os.getenv "LUNARVIM_RUNTIME_DIR" .. path_sep .. "lvim")
  71. vim.opt.rtp:remove(join_paths(vim.fn.stdpath "data", "site"))
  72. vim.opt.rtp:remove(join_paths(vim.fn.stdpath "data", "site", "after"))
  73. vim.opt.rtp:prepend(join_paths(self.runtime_dir, "site"))
  74. vim.opt.rtp:append(join_paths(self.runtime_dir, "site", "after"))
  75. vim.opt.rtp:remove(vim.fn.stdpath "config")
  76. vim.opt.rtp:remove(join_paths(vim.fn.stdpath "config", "after"))
  77. vim.opt.rtp:prepend(self.config_dir)
  78. vim.opt.rtp:append(join_paths(self.config_dir, "after"))
  79. -- TODO: we need something like this: vim.opt.packpath = vim.opt.rtp
  80. vim.cmd [[let &packpath = &runtimepath]]
  81. end
  82. -- FIXME: currently unreliable in unit-tests
  83. if not in_headless then
  84. _G.PLENARY_DEBUG = false
  85. require("lvim.impatient").setup {
  86. path = join_paths(self.cache_dir, "lvim_cache"),
  87. enable_profiling = true,
  88. }
  89. end
  90. require("lvim.config"):init()
  91. require("lvim.plugin-loader").init {
  92. package_root = self.pack_dir,
  93. install_path = self.packer_install_dir,
  94. }
  95. return self
  96. end
  97. ---Update LunarVim
  98. ---pulls the latest changes from github and, resets the startup cache
  99. function M:update()
  100. require_clean("lvim.utils.hooks").run_pre_update()
  101. require_clean("lvim.utils.git").update_base_lvim()
  102. require_clean("lvim.utils.hooks").run_post_update()
  103. end
  104. return M