diff options
author | 最萌小汐 <sumneko@hotmail.com> | 2022-07-05 21:15:08 +0800 |
---|---|---|
committer | 最萌小汐 <sumneko@hotmail.com> | 2022-07-05 21:15:08 +0800 |
commit | 48c53a36c6bad6662aabc8af98fb58d54ad9a498 (patch) | |
tree | fc2cfcfdfbb761f810d43030b3f948cae86f00c7 /script | |
parent | 55166a406c56de8fe9f6932fabf9ca1c3cca469a (diff) | |
download | lua-language-server-48c53a36c6bad6662aabc8af98fb58d54ad9a498.zip |
resolve #1065 show detail for `doc.type.table`
Diffstat (limited to 'script')
-rw-r--r-- | script/core/hover/label.lua | 3 | ||||
-rw-r--r-- | script/vm/infer.lua | 40 |
2 files changed, 40 insertions, 3 deletions
diff --git a/script/core/hover/label.lua b/script/core/hover/label.lua index a91ca074..5befe84c 100644 --- a/script/core/hover/label.lua +++ b/script/core/hover/label.lua @@ -55,7 +55,8 @@ local function asValue(source, title) and ( type == 'table' or type == 'any' or type == 'unknown' - or type == 'nil') then + or type == 'nil' + or type:sub(1, 1) == '{') then else pack[#pack+1] = type end diff --git a/script/vm/infer.lua b/script/vm/infer.lua index d30ba36c..b1b7183e 100644 --- a/script/vm/infer.lua +++ b/script/vm/infer.lua @@ -8,6 +8,7 @@ local vm = require 'vm.vm' ---@field views table<string, boolean> ---@field cachedView? string ---@field node? vm.node +---@field _drop table local mt = {} mt.__index = mt mt._hasNumber = false @@ -122,11 +123,45 @@ local viewNodeSwitch = util.switch() for i, sign in ipairs(source.signs) do buf[i] = vm.getInfer(sign):view(uri) end + if infer._drop then + local node = vm.compileNode(source) + for c in node:eachObject() do + if guide.isLiteral(c) then + infer._drop[c] = true + end + end + end return ('%s<%s>'):format(source.node[1], table.concat(buf, ', ')) end) : case 'doc.type.table' - : call(function (source, infer) - infer._hasTable = true + : call(function (source, infer, uri) + if #source.fields == 0 then + infer._hasTable = true + return + end + if infer._drop and infer._drop[source] then + infer._hasTable = true + return + end + infer._hasClass = true + local buf = {} + buf[#buf+1] = '{ ' + for i, field in ipairs(source.fields) do + if i > 1 then + buf[#buf+1] = ', ' + end + local key = field.name + if key.type == 'doc.type' then + buf[#buf+1] = ('[%s]: '):format(vm.getInfer(key):view(uri)) + elseif type(key[1]) == 'string' then + buf[#buf+1] = key[1] .. ': ' + else + buf[#buf+1] = ('[%q]: '):format(key[1]) + end + buf[#buf+1] = vm.getInfer(field.extends):view(uri) + end + buf[#buf+1] = ' }' + return table.concat(buf) end) : case 'doc.type.string' : call(function (source, infer) @@ -209,6 +244,7 @@ function vm.getInfer(source) end local infer = setmetatable({ node = node, + _drop = {}, }, mt) node.lastInfer = infer |