diff --git a/lua/ibl/config.lua b/lua/ibl/config.lua index a80be4a..9cc5c75 100644 --- a/lua/ibl/config.lua +++ b/lua/ibl/config.lua @@ -137,7 +137,7 @@ local validate_config = function(config) repeat_linebreak = { config.indent.repeat_linebreak, "boolean", true }, }, config.indent, "ibl.config.indent") if config.indent.char then - vim.validate { + utils.validate { char = { config.indent.char, validate_char, @@ -146,7 +146,7 @@ local validate_config = function(config) } end if config.indent.tab_char then - vim.validate { + utils.validate { tab_char = { config.indent.tab_char, validate_char, @@ -155,7 +155,7 @@ local validate_config = function(config) } end if type(config.indent.highlight) == "table" then - vim.validate { + utils.validate { tab_char = { config.indent.highlight, function(highlight) @@ -173,7 +173,7 @@ local validate_config = function(config) remove_blankline_trail = { config.whitespace.remove_blankline_trail, "boolean", true }, }, config.whitespace, "ibl.config.whitespace") if type(config.whitespace.highlight) == "table" then - vim.validate { + utils.validate { tab_char = { config.whitespace.highlight, function(highlight) @@ -199,7 +199,7 @@ local validate_config = function(config) exclude = { config.scope.exclude, "table", true }, }, config.scope, "ibl.config.scope") if config.scope.char then - vim.validate { + utils.validate { char = { config.scope.char, validate_char, @@ -208,7 +208,7 @@ local validate_config = function(config) } end if type(config.scope.highlight) == "table" then - vim.validate { + utils.validate { tab_char = { config.scope.highlight, function(highlight) diff --git a/lua/ibl/hooks.lua b/lua/ibl/hooks.lua index e59d89c..56b7972 100644 --- a/lua/ibl/hooks.lua +++ b/lua/ibl/hooks.lua @@ -58,7 +58,7 @@ local count = 0 ---@overload fun(type: 'CLEAR', cb: ibl.hooks.cb.clear, opts: ibl.hooks.options?): string ---@overload fun(type: 'HIGHLIGHT_SETUP', cb: ibl.hooks.cb.highlight_setup, opts: ibl.hooks.options?): string M.register = function(type, cb, opts) - vim.validate { + utils.validate { type = { type, function(t) @@ -70,7 +70,7 @@ M.register = function(type, cb, opts) opts = { opts, "table", true }, } opts = vim.tbl_deep_extend("keep", opts or {}, default_opts) - vim.validate { + utils.validate { bufnr = { opts.bufnr, "number", true }, } if opts.bufnr then @@ -105,7 +105,7 @@ end --- ---@param id string M.clear = function(id) - vim.validate { id = { id, "string" } } + utils.validate { id = { id, "string" } } local type, hook_id = unpack(utils.split(id, "_")) if not type or not hook_id or not utils.tbl_contains(M.type, type) then return diff --git a/lua/ibl/utils.lua b/lua/ibl/utils.lua index 2e39509..b30fc0e 100644 --- a/lua/ibl/utils.lua +++ b/lua/ibl/utils.lua @@ -9,11 +9,25 @@ M.get_whitespace = function(line) return string.match(line, "^%s+") or "" end +--- Use the faster validate version if available. +---@param spec table +M.validate = function(spec) + if vim.fn.has "nvim-0.11" == 1 then + for key, key_spec in pairs(spec) do + local message = type(key_spec[3]) == "string" and key_spec[3] or nil + local optional = type(key_spec[3]) == "boolean" and key_spec[3] or nil + vim.validate(key, key_spec[1], key_spec[2], optional, message) + end + else + vim.validate(spec) + end +end + ---@param opt table ---@param input table ---@param path string M.validate_config = function(opt, input, path) - vim.validate(opt) + M.validate(opt) for key, _ in pairs(input) do if not opt[key] then error(string.format("'%s' is not a valid key of %s", key, path))