From 3a84e5be8840d7fe2bf98f7f268f07489a3bb30f Mon Sep 17 00:00:00 2001 From: Björn Linse Date: Mon, 14 Jan 2019 18:08:17 +0100 Subject: lua: expose full interface of vim.inspect and add test Implement lazy loading for vim.submodule, this would be over-engineering for inspect only, but we expect to use this solution also for more and larger modules. --- src/nvim/lua/vim.lua | 20 +++++++++++--------- 1 file changed, 11 insertions(+), 9 deletions(-) (limited to 'src/nvim/lua/vim.lua') diff --git a/src/nvim/lua/vim.lua b/src/nvim/lua/vim.lua index df75cc4ade..b0d0bfc74b 100644 --- a/src/nvim/lua/vim.lua +++ b/src/nvim/lua/vim.lua @@ -152,14 +152,6 @@ local function gsplit(s, sep, plain) end end -local inspect = (function() - local f - return function(...) - if f == nil then f = require('vim.inspect') end - return f(...) - end -end)() - local function split(s,sep,plain) local t={} for c in gsplit(s, sep, plain) do table.insert(t,c) end return t @@ -195,6 +187,13 @@ deepcopy = function(orig) return deepcopy_funcs[type(orig)](orig) end +local function __index(table, key) + if key == "inspect" then + table.inspect = require("vim.inspect") + return table.inspect + end +end + local module = { _update_package_paths = _update_package_paths, _os_proc_children = _os_proc_children, @@ -204,7 +203,10 @@ local module = { split = split, gsplit = gsplit, deepcopy = deepcopy, - inspect = inspect, } +setmetatable(module, { + __index = __index +}) + return module -- cgit