init.lua 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. local utils = {}
  2. local Log = require "core.log"
  3. local uv = vim.loop
  4. -- recursive Print (structure, limit, separator)
  5. local function r_inspect_settings(structure, limit, separator)
  6. limit = limit or 100 -- default item limit
  7. separator = separator or "." -- indent string
  8. if limit < 1 then
  9. print "ERROR: Item limit reached."
  10. return limit - 1
  11. end
  12. if structure == nil then
  13. io.write("-- O", separator:sub(2), " = nil\n")
  14. return limit - 1
  15. end
  16. local ts = type(structure)
  17. if ts == "table" then
  18. for k, v in pairs(structure) do
  19. -- replace non alpha keys with ["key"]
  20. if tostring(k):match "[^%a_]" then
  21. k = '["' .. tostring(k) .. '"]'
  22. end
  23. limit = r_inspect_settings(v, limit, separator .. "." .. tostring(k))
  24. if limit < 0 then
  25. break
  26. end
  27. end
  28. return limit
  29. end
  30. if ts == "string" then
  31. -- escape sequences
  32. structure = string.format("%q", structure)
  33. end
  34. separator = separator:gsub("%.%[", "%[")
  35. if type(structure) == "function" then
  36. -- don't print functions
  37. io.write("-- lvim", separator:sub(2), " = function ()\n")
  38. else
  39. io.write("lvim", separator:sub(2), " = ", tostring(structure), "\n")
  40. end
  41. return limit - 1
  42. end
  43. function utils.generate_settings()
  44. -- Opens a file in append mode
  45. local file = io.open("lv-settings.lua", "w")
  46. -- sets the default output file as test.lua
  47. io.output(file)
  48. -- write all `lvim` related settings to `lv-settings.lua` file
  49. r_inspect_settings(lvim, 10000, ".")
  50. -- closes the open file
  51. io.close(file)
  52. end
  53. -- autoformat
  54. function utils.toggle_autoformat()
  55. if lvim.format_on_save then
  56. require("core.autocmds").define_augroups {
  57. autoformat = {
  58. {
  59. "BufWritePre",
  60. "*",
  61. ":silent lua vim.lsp.buf.formatting_sync()",
  62. },
  63. },
  64. }
  65. Log:debug "Format on save active"
  66. end
  67. if not lvim.format_on_save then
  68. vim.cmd [[
  69. if exists('#autoformat#BufWritePre')
  70. :autocmd! autoformat
  71. endif
  72. ]]
  73. Log:debug "Format on save off"
  74. end
  75. end
  76. function utils.reload_lv_config()
  77. require("core.lualine").config()
  78. local config = require "config"
  79. config:load()
  80. require("keymappings").setup() -- this should be done before loading the plugins
  81. vim.cmd("source " .. utils.join_paths(get_runtime_dir(), "lvim", "lua", "plugins.lua"))
  82. local plugins = require "plugins"
  83. utils.toggle_autoformat()
  84. local plugin_loader = require "plugin-loader"
  85. plugin_loader:cache_reset()
  86. plugin_loader:load { plugins, lvim.plugins }
  87. vim.cmd ":PackerInstall"
  88. vim.cmd ":PackerCompile"
  89. -- vim.cmd ":PackerClean"
  90. local null_ls = require "lsp.null-ls"
  91. null_ls.setup(vim.bo.filetype, { force_reload = true })
  92. Log:info "Reloaded configuration"
  93. end
  94. function utils.unrequire(m)
  95. package.loaded[m] = nil
  96. _G[m] = nil
  97. end
  98. function utils.gsub_args(args)
  99. if args == nil or type(args) ~= "table" then
  100. return args
  101. end
  102. local buffer_filepath = vim.fn.fnameescape(vim.api.nvim_buf_get_name(0))
  103. for i = 1, #args do
  104. args[i] = string.gsub(args[i], "${FILEPATH}", buffer_filepath)
  105. end
  106. return args
  107. end
  108. --- Returns a table with the default values that are missing.
  109. --- either paramter can be empty.
  110. --@param config (table) table containing entries that take priority over defaults
  111. --@param default_config (table) table contatining default values if found
  112. function utils.apply_defaults(config, default_config)
  113. config = config or {}
  114. default_config = default_config or {}
  115. local new_config = vim.tbl_deep_extend("keep", vim.empty_dict(), config)
  116. new_config = vim.tbl_deep_extend("keep", new_config, default_config)
  117. return new_config
  118. end
  119. --- Checks whether a given path exists and is a file.
  120. --@param filename (string) path to check
  121. --@returns (bool)
  122. function utils.is_file(filename)
  123. local stat = uv.fs_stat(filename)
  124. return stat and stat.type == "file" or false
  125. end
  126. function utils.join_paths(...)
  127. local path_sep = vim.loop.os_uname().version:match "Windows" and "\\" or "/"
  128. local result = table.concat(vim.tbl_flatten { ... }, path_sep):gsub(path_sep .. "+", path_sep)
  129. return result
  130. end
  131. function utils.lvim_cache_reset()
  132. _G.__luacache.clear_cache()
  133. _G.__luacache.save_cache()
  134. require("plugin-loader"):cache_reset()
  135. end
  136. vim.cmd [[ command! LvimCacheReset lua require('utils').lvim_cache_reset() ]]
  137. return utils
  138. -- TODO: find a new home for these autocommands