diff options
| author | kylo252 <[email protected]> | 2022-10-04 19:23:52 +0200 | 
|---|---|---|
| committer | GitHub <[email protected]> | 2022-10-04 13:23:52 -0400 | 
| commit | e5bcf01c759e7c833d8a5f1fcf665b6ea32a7c16 (patch) | |
| tree | 51b68c8face9faa2a41fcc8103b6296213557d4b /lua/lvim/utils | |
| parent | 560ee4d7cf4038a22a5556d79ad92cd226a792dc (diff) | |
refactor: more deliberate reload (#3133)
Diffstat (limited to 'lua/lvim/utils')
| -rw-r--r-- | lua/lvim/utils/hooks.lua | 2 | ||||
| -rw-r--r-- | lua/lvim/utils/modules.lua (renamed from lua/lvim/utils/reload.lua) | 32 | 
2 files changed, 26 insertions, 8 deletions
| diff --git a/lua/lvim/utils/hooks.lua b/lua/lvim/utils/hooks.lua index fd78ef19..4101c573 100644 --- a/lua/lvim/utils/hooks.lua +++ b/lua/lvim/utils/hooks.lua @@ -61,7 +61,7 @@ function M.run_post_update()      vim.wait(1000, function()        return false      end) -    local ret = require_clean("lvim.utils.git").switch_lvim_branch(compat_tag) +    local ret = reload("lvim.utils.git").switch_lvim_branch(compat_tag)      if ret then        vim.notify("Reverted to the last known compatible version: " .. compat_tag, vim.log.levels.WARN)      end diff --git a/lua/lvim/utils/reload.lua b/lua/lvim/utils/modules.lua index 46392349..d5674483 100644 --- a/lua/lvim/utils/reload.lua +++ b/lua/lvim/utils/modules.lua @@ -1,5 +1,6 @@  local M = {} +local Log = require "lvim.core.log"  -- revisit this  -- function prequire(package)  --   local status, lib = pcall(require, package) @@ -42,7 +43,9 @@ local function _replace(old, new, repeat_tbl)        old[k] = new[k]      else        if type(old[k]) ~= type(new[k]) then -        vim.notify(string.format("warning: attr %s old type no equal new type!!!", k)) +        Log:debug( +          string.format("Reloader: mismatch between old [%s] and new [%s] type for [%s]", type(old[k]), type(new[k]), k) +        )          _assign(old, new, k)        else          if type(old[k]) == "table" then @@ -55,25 +58,40 @@ local function _replace(old, new, repeat_tbl)    end  end +M.require_clean = function(m) +  package.loaded[m] = nil +  _G[m] = nil +  local _, module = pcall(require, m) +  return module +end + +M.require_safe = function(mod) +  local status_ok, module = pcall(require, mod) +  if not status_ok then +    local trace = debug.getinfo(2, "SL") +    local shorter_src = trace.short_src +    local lineinfo = shorter_src .. ":" .. (trace.currentline or trace.linedefined) +    local msg = string.format("%s : skipped loading [%s]", lineinfo, mod) +    Log:debug(msg) +  end +  return module +end +  M.reload = function(mod)    if not package.loaded[mod] then -    local m = require(mod) -    return m +    return M.require_safe(mod)    end -  -- vim.notify "begin reload!!!"    local old = package.loaded[mod]    package.loaded[mod] = nil -  local new = require(mod) +  local new = M.require_safe(mod)    if type(old) == "table" and type(new) == "table" then -    -- vim.notify "pick object in new module to old module!!!"      local repeat_tbl = {}      _replace(old, new, repeat_tbl)    end    package.loaded[mod] = old -  -- vim.notify "finish reload!!!"    return old  end | 
