| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205 | local utils = {}local Log = require "lvim.core.log"local uv = vim.loop-- recursive Print (structure, limit, separator)local function r_inspect_settings(structure, limit, separator)  limit = limit or 100 -- default item limit  separator = separator or "." -- indent string  if limit < 1 then    print "ERROR: Item limit reached."    return limit - 1  end  if structure == nil then    io.write("-- O", separator:sub(2), " = nil\n")    return limit - 1  end  local ts = type(structure)  if ts == "table" then    for k, v in pairs(structure) do      -- replace non alpha keys with ["key"]      if tostring(k):match "[^%a_]" then        k = '["' .. tostring(k) .. '"]'      end      limit = r_inspect_settings(v, limit, separator .. "." .. tostring(k))      if limit < 0 then        break      end    end    return limit  end  if ts == "string" then    -- escape sequences    structure = string.format("%q", structure)  end  separator = separator:gsub("%.%[", "%[")  if type(structure) == "function" then    -- don't print functions    io.write("-- lvim", separator:sub(2), " = function ()\n")  else    io.write("lvim", separator:sub(2), " = ", tostring(structure), "\n")  end  return limit - 1endfunction utils.generate_settings()  -- Opens a file in append mode  local file = io.open("lv-settings.lua", "w")  -- sets the default output file as test.lua  io.output(file)  -- write all `lvim` related settings to `lv-settings.lua` file  r_inspect_settings(lvim, 10000, ".")  -- closes the open file  io.close(file)end-- autoformatfunction utils.toggle_autoformat()  if lvim.format_on_save then    require("lvim.core.autocmds").define_augroups {      autoformat = {        {          "BufWritePre",          "*",          ":silent lua vim.lsp.buf.formatting_sync()",        },      },    }    Log:debug "Format on save active"  end  if not lvim.format_on_save then    vim.cmd [[      if exists('#autoformat#BufWritePre')        :autocmd! autoformat      endif    ]]    Log:debug "Format on save off"  endendfunction utils.unrequire(m)  package.loaded[m] = nil  _G[m] = nilendfunction utils.gsub_args(args)  if args == nil or type(args) ~= "table" then    return args  end  local buffer_filepath = vim.fn.fnameescape(vim.api.nvim_buf_get_name(0))  for i = 1, #args do    args[i] = string.gsub(args[i], "${FILEPATH}", buffer_filepath)  end  return argsend--- Returns a table with the default values that are missing.--- either paramter can be empty.--@param config (table) table containing entries that take priority over defaults--@param default_config (table) table contatining default values if foundfunction utils.apply_defaults(config, default_config)  config = config or {}  default_config = default_config or {}  local new_config = vim.tbl_deep_extend("keep", vim.empty_dict(), config)  new_config = vim.tbl_deep_extend("keep", new_config, default_config)  return new_configend--- Checks whether a given path exists and is a file.--@param path (string) path to check--@returns (bool)function utils.is_file(path)  local stat = uv.fs_stat(path)  return stat and stat.type == "file" or falseend--- Checks whether a given path exists and is a directory--@param path (string) path to check--@returns (bool)function utils.is_directory(path)  local stat = uv.fs_stat(path)  return stat and stat.type == "directory" or falseendutils.join_paths = _G.join_pathsfunction utils.write_file(path, txt, flag)  uv.fs_open(path, flag, 438, function(open_err, fd)    assert(not open_err, open_err)    uv.fs_write(fd, txt, -1, function(write_err)      assert(not write_err, write_err)      uv.fs_close(fd, function(close_err)        assert(not close_err, close_err)      end)    end)  end)endfunction utils.debounce(ms, fn)  local timer = vim.loop.new_timer()  return function(...)    local argv = { ... }    timer:start(ms, 0, function()      timer:stop()      vim.schedule_wrap(fn)(unpack(argv))    end)  endendfunction utils.search_file(file, args)  local Job = require "plenary.job"  local stderr = {}  local stdout, ret = Job    :new({      command = "grep",      args = { args, file },      cwd = get_cache_dir(),      on_stderr = function(_, data)        table.insert(stderr, data)      end,    })    :sync()  return stdout, ret, stderrendfunction utils.file_contains(file, query)  local stdout, ret, stderr = utils.search_file(file, query)  if ret == 0 then    return true  end  if not vim.tbl_isempty(stderr) then    error(vim.inspect(stderr))  end  if not vim.tbl_isempty(stdout) then    error(vim.inspect(stdout))  end  return falseendfunction utils.log_contains(query)  local logfile = require("lvim.core.log"):get_path()  local stdout, ret, stderr = utils.search_file(logfile, query)  if ret == 0 then    return true  end  if not vim.tbl_isempty(stderr) then    error(vim.inspect(stderr))  end  if not vim.tbl_isempty(stdout) then    error(vim.inspect(stdout))  end  if not vim.tbl_isempty(stderr) then    error(vim.inspect(stderr))  end  return falseendreturn utils-- TODO: find a new home for these autocommands
 |