init.lua 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  1. local utils = {}
  2. local Log = require "lvim.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("lvim.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.unrequire(m)
  77. package.loaded[m] = nil
  78. _G[m] = nil
  79. end
  80. function utils.gsub_args(args)
  81. if args == nil or type(args) ~= "table" then
  82. return args
  83. end
  84. local buffer_filepath = vim.fn.fnameescape(vim.api.nvim_buf_get_name(0))
  85. for i = 1, #args do
  86. args[i] = string.gsub(args[i], "${FILEPATH}", buffer_filepath)
  87. end
  88. return args
  89. end
  90. --- Returns a table with the default values that are missing.
  91. --- either paramter can be empty.
  92. --@param config (table) table containing entries that take priority over defaults
  93. --@param default_config (table) table contatining default values if found
  94. function utils.apply_defaults(config, default_config)
  95. config = config or {}
  96. default_config = default_config or {}
  97. local new_config = vim.tbl_deep_extend("keep", vim.empty_dict(), config)
  98. new_config = vim.tbl_deep_extend("keep", new_config, default_config)
  99. return new_config
  100. end
  101. --- Checks whether a given path exists and is a file.
  102. --@param path (string) path to check
  103. --@returns (bool)
  104. function utils.is_file(path)
  105. local stat = uv.fs_stat(path)
  106. return stat and stat.type == "file" or false
  107. end
  108. --- Checks whether a given path exists and is a directory
  109. --@param path (string) path to check
  110. --@returns (bool)
  111. function utils.is_directory(path)
  112. local stat = uv.fs_stat(path)
  113. return stat and stat.type == "directory" or false
  114. end
  115. utils.join_paths = _G.join_paths
  116. function utils.write_file(path, txt, flag)
  117. uv.fs_open(path, flag, 438, function(open_err, fd)
  118. assert(not open_err, open_err)
  119. uv.fs_write(fd, txt, -1, function(write_err)
  120. assert(not write_err, write_err)
  121. uv.fs_close(fd, function(close_err)
  122. assert(not close_err, close_err)
  123. end)
  124. end)
  125. end)
  126. end
  127. function utils.debounce(ms, fn)
  128. local timer = vim.loop.new_timer()
  129. return function(...)
  130. local argv = { ... }
  131. timer:start(ms, 0, function()
  132. timer:stop()
  133. vim.schedule_wrap(fn)(unpack(argv))
  134. end)
  135. end
  136. end
  137. function utils.search_file(file, args)
  138. local Job = require "plenary.job"
  139. local stderr = {}
  140. local stdout, ret = Job
  141. :new({
  142. command = "grep",
  143. args = { args, file },
  144. cwd = get_cache_dir(),
  145. on_stderr = function(_, data)
  146. table.insert(stderr, data)
  147. end,
  148. })
  149. :sync()
  150. return stdout, ret, stderr
  151. end
  152. function utils.file_contains(file, query)
  153. local stdout, ret, stderr = utils.search_file(file, query)
  154. if ret == 0 then
  155. return true
  156. end
  157. if not vim.tbl_isempty(stderr) then
  158. error(vim.inspect(stderr))
  159. end
  160. if not vim.tbl_isempty(stdout) then
  161. error(vim.inspect(stdout))
  162. end
  163. return false
  164. end
  165. function utils.log_contains(query)
  166. local logfile = require("lvim.core.log"):get_path()
  167. local stdout, ret, stderr = utils.search_file(logfile, query)
  168. if ret == 0 then
  169. return true
  170. end
  171. if not vim.tbl_isempty(stderr) then
  172. error(vim.inspect(stderr))
  173. end
  174. if not vim.tbl_isempty(stdout) then
  175. error(vim.inspect(stdout))
  176. end
  177. if not vim.tbl_isempty(stderr) then
  178. error(vim.inspect(stderr))
  179. end
  180. return false
  181. end
  182. return utils
  183. -- TODO: find a new home for these autocommands