feat(deprecations): vim._defer_deprecated_module()

This commit is contained in:
Justin M. Keyes 2024-10-17 17:57:14 +02:00
parent 0083e03d6f
commit c9c17fda80

View File

@ -1164,6 +1164,32 @@ function vim._defer_require(root, mod)
}) })
end end
--- @private
--- Creates a module alias/shim that lazy-loads a target module.
---
--- Unlike `vim.defaulttable()` this also:
--- - implements __call
--- - calls vim.deprecate()
---
--- @param old_name string Name of the deprecated module, which will be shimmed.
--- @param new_name string Name of the new module, which will be loaded by require().
function vim._defer_deprecated_module(old_name, new_name)
return setmetatable({}, {
---@param _ table<string, any>
---@param k string
__index = function(_, k)
vim.deprecate(old_name, new_name, '2.0.0', nil, false)
local target = require(new_name)
return target[k]
end,
__call = function(self)
vim.deprecate(old_name, new_name, '2.0.0', nil, false)
local target = require(new_name)
return target(self)
end,
})
end
--- @nodoc --- @nodoc
--- @class vim.context.mods --- @class vim.context.mods
--- @field bo? table<string, any> --- @field bo? table<string, any>