summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author最萌小汐 <sumneko@hotmail.com>2019-11-28 20:35:19 +0800
committer最萌小汐 <sumneko@hotmail.com>2019-11-28 20:35:19 +0800
commita64957132d5c9ecf6c66003ff028d68772d1aa1f (patch)
tree2df5dee56cd1166b1c87c9f62ad3e268dafe48d6
parent1038520109da932c2e648da6ffa9bf25d36944b8 (diff)
downloadlua-language-server-a64957132d5c9ecf6c66003ff028d68772d1aa1f.zip
hover 显示 table
-rw-r--r--script-beta/core/hover/class.lua9
-rw-r--r--script-beta/core/hover/name.lua2
-rw-r--r--script-beta/core/hover/table.lua48
-rw-r--r--test-beta/hover/init.lua10
4 files changed, 46 insertions, 23 deletions
diff --git a/script-beta/core/hover/class.lua b/script-beta/core/hover/class.lua
index 6d28ee8a..be7b3995 100644
--- a/script-beta/core/hover/class.lua
+++ b/script-beta/core/hover/class.lua
@@ -5,7 +5,14 @@ local function getClass(source, deep)
return nil
end
local class = vm.eachField(source, function (info)
- if info.key == 's|type' or info.key == 's|__name' or info.key == 's|name' then
+ if not info.key then
+ return
+ end
+ local lkey = info.key:lower()
+ if lkey == 's|type'
+ or lkey == 's|__name'
+ or lkey == 's|name'
+ or lkey == 's|class' then
if info.value and info.value.type == 'string' then
return info.value[1]
end
diff --git a/script-beta/core/hover/name.lua b/script-beta/core/hover/name.lua
index 0d5f65ad..b96a8169 100644
--- a/script-beta/core/hover/name.lua
+++ b/script-beta/core/hover/name.lua
@@ -42,7 +42,7 @@ local function buildName(source)
return asMethod(source) or ''
end
if source.type == 'setfield'
- or source.tyoe == 'getfield' then
+ or source.type == 'getfield' then
return asField(source) or ''
end
if source.type == 'tablefield' then
diff --git a/script-beta/core/hover/table.lua b/script-beta/core/hover/table.lua
index 9ed86692..9292d183 100644
--- a/script-beta/core/hover/table.lua
+++ b/script-beta/core/hover/table.lua
@@ -1,35 +1,51 @@
-local vm = require 'vm'
+local vm = require 'vm'
+local util = require 'utility'
+local getClass = require 'core.hover.class'
-local function checkClass(source)
+local function getKey(info)
+ local ktype = info.key:sub(1, 2)
+ if ktype == 's|' then
+ return info.key:sub(3)
+ end
+ return ('[%s]'):format(info.key:sub(3))
+end
+
+local function getField(info)
+ local type = vm.getType(info.source)
+ local class = getClass(info.source)
+ local literal = vm.getLiteral(info.source)
+ local key = getKey(info)
+ local label
+ if literal then
+ label = ('%s: %s = %s'):format(key, class or type, util.viewLiteral(literal))
+ else
+ label = ('%s: %s'):format(key, class or type)
+ end
+ return label, key
end
return function (source)
local fields = {}
- local class
+ local keys = {}
vm.eachField(source, function (info)
- if info.key == 's|type' or info.key == 's|__name' or info.key == 's|name' then
- if info.value and info.value.type == 'string' then
- class = info.value[1]
- end
- end
- local type = vm.getType(info.source)
- fields[#fields+1] = ('%s'):format(type)
+ local field, key = getField(info)
+ fields[#fields+1] = field
+ keys[field] = key
end)
local fieldsBuf
if #fields == 0 then
fieldsBuf = '{}'
else
+ table.sort(fields, function (a, b)
+ return keys[a] < keys[b]
+ end)
local lines = {}
lines[#lines+1] = '{'
for _, field in ipairs(fields) do
- lines[#lines+1] = ' ' .. field
+ lines[#lines+1] = ' ' .. field .. ','
end
lines[#lines+1] = '}'
fieldsBuf = table.concat(lines, '\n')
end
- if class then
- return ('%s %s'):format(class, fieldsBuf)
- else
- return fieldsBuf
- end
+ return fieldsBuf
end
diff --git a/test-beta/hover/init.lua b/test-beta/hover/init.lua
index c5e48aba..744d2328 100644
--- a/test-beta/hover/init.lua
+++ b/test-beta/hover/init.lua
@@ -184,7 +184,7 @@ local <?obj?> = setmetatable({}, mt)
]]
[[
local obj: class {
- __index: table,
+ __index: class,
name: string = "class",
}
]]
@@ -197,9 +197,9 @@ mt.__index = mt
local <?obj?> = setmetatable({}, mt)
]]
[[
-local obj: *class {
+local obj: class {
TYPE: string = "class",
- __index: table,
+ __index: class,
}
]]
@@ -211,9 +211,9 @@ mt.__index = mt
local <?obj?> = setmetatable({}, mt)
]]
[[
-local obj: *class {
+local obj: class {
Class: string = "class",
- __index: table,
+ __index: class,
}
]]