diff options
author | Thomas Vigouroux <thomas.vigouroux@protonmail.com> | 2022-09-07 08:39:56 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-09-07 08:39:56 +0200 |
commit | fd1595514b747d8b083f78007579d869ccfbe89c (patch) | |
tree | 41e52c9e43db9351de3aa33a8628b76db07906c3 /runtime/lua/vim/shared.lua | |
parent | f32fd19f1eedbd75e6a37b73f28cf8761e0e875c (diff) | |
download | rneovim-fd1595514b747d8b083f78007579d869ccfbe89c.tar.gz rneovim-fd1595514b747d8b083f78007579d869ccfbe89c.tar.bz2 rneovim-fd1595514b747d8b083f78007579d869ccfbe89c.zip |
Use weak tables in tree-sitter code (#17117)
feat(treesitter): use weak tables when possible
Also add the defaulttable function to create a table whose values are created when a key is missing.
Diffstat (limited to 'runtime/lua/vim/shared.lua')
-rw-r--r-- | runtime/lua/vim/shared.lua | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/runtime/lua/vim/shared.lua b/runtime/lua/vim/shared.lua index e1b4ed4ea9..59cb669609 100644 --- a/runtime/lua/vim/shared.lua +++ b/runtime/lua/vim/shared.lua @@ -715,5 +715,30 @@ function vim.is_callable(f) return type(m.__call) == 'function' end +--- Creates a table whose members are automatically created when accessed, if they don't already +--- exist. +--- +--- They mimic defaultdict in python. +--- +--- If @p create is @c nil, this will create a defaulttable whose constructor function is +--- this function, effectively allowing to create nested tables on the fly: +--- +--- <pre> +--- local a = vim.defaulttable() +--- a.b.c = 1 +--- </pre> +--- +---@param create function|nil The function called to create a missing value. +---@return table Empty table with metamethod +function vim.defaulttable(create) + create = create or vim.defaulttable + return setmetatable({}, { + __index = function(tbl, key) + rawset(tbl, key, create()) + return rawget(tbl, key) + end, + }) +end + return vim -- vim:sw=2 ts=2 et |