summaryrefslogtreecommitdiff
path: root/script
diff options
context:
space:
mode:
Diffstat (limited to 'script')
-rw-r--r--script/core/completion.lua8
-rw-r--r--script/core/hover/init.lua164
-rw-r--r--script/provider/markdown.lua9
-rw-r--r--script/provider/provider.lua10
4 files changed, 48 insertions, 143 deletions
diff --git a/script/core/completion.lua b/script/core/completion.lua
index 06219e74..dc4ddf28 100644
--- a/script/core/completion.lua
+++ b/script/core/completion.lua
@@ -191,13 +191,7 @@ local function buildDesc(source)
return
end
local hover = getHover.get(source)
- local md = markdown()
- md:add('lua', hover.label)
- md:splitLine()
- md:add('md', hover.description)
- md:splitLine()
- md:add('lua', getSnip(source))
- return md
+ return hover
end
local function buildFunction(results, source, value, oop, data)
diff --git a/script/core/hover/init.lua b/script/core/hover/init.lua
index c6c2d92e..6e98d6c9 100644
--- a/script/core/hover/init.lua
+++ b/script/core/hover/init.lua
@@ -1,145 +1,55 @@
local files = require 'files'
-local searcher = require 'core.searcher'
local vm = require 'vm'
local getLabel = require 'core.hover.label'
local getDesc = require 'core.hover.description'
local util = require 'utility'
local findSource = require 'core.find-source'
-local lang = require 'language'
local markdown = require 'provider.markdown'
local infer = require 'core.infer'
-local function eachFunctionAndOverload(value, callback)
- callback(value)
- if not value.bindDocs then
- return
- end
- for _, doc in ipairs(value.bindDocs) do
- if doc.type == 'doc.overload' then
- callback(doc.overload)
- end
- end
-end
+local function getHover(source)
+ local md = markdown()
+ local defMark = {}
+ local labelMark = {}
+ local descMark = {}
-local function getHoverAsValue(source)
- local label = getLabel(source)
- local desc = getDesc(source)
- if not desc then
- local values = vm.getDefs(source)
- for _, def in ipairs(values) do
- desc = getDesc(def)
- if desc then
- break
- end
+ local function addHover(def)
+ if defMark[def] then
+ return
end
- end
- return {
- label = label,
- source = source,
- description = desc,
- }
-end
+ defMark[def] = true
-local function getHoverAsFunction(source)
- local values = vm.getDefs(source)
- local desc = getDesc(source)
- local labels = {}
- local defs = 0
- local protos = 0
- local other = 0
- local mark = {}
- for _, def in ipairs(values) do
- def = searcher.getObjectValue(def) or def
- if def.type == 'function'
- or def.type == 'doc.type.function' then
- eachFunctionAndOverload(def, function (value)
- if mark[value] then
- return
- end
- mark[value] =true
- local label = getLabel(value)
- if label then
- defs = defs + 1
- labels[label] = (labels[label] or 0) + 1
- if labels[label] == 1 then
- protos = protos + 1
- end
- end
- desc = desc or getDesc(value)
- end)
- elseif def.type == 'table'
- or def.type == 'boolean'
- or def.type == 'string'
- or def.type == 'integer'
- or def.type == 'number' then
- other = other + 1
- desc = desc or getDesc(def)
- end
- end
+ local label = getLabel(def)
+ local desc = getDesc(def)
- if defs == 0 then
- return getHoverAsValue(source)
- end
+ if not labelMark[tostring(label)] then
+ labelMark[tostring(label)] = true
+ md:add('lua', label)
+ md:splitLine()
+ end
- if defs == 1 and other == 0 then
- return {
- label = next(labels),
- source = source,
- description = desc,
- }
+ if not descMark[tostring(desc)] then
+ descMark[tostring(desc)] = true
+ md:add('md', desc)
+ md:splitLine()
+ end
end
- local lines = {}
- if defs > 1 then
- lines[#lines+1] = lang.script('HOVER_MULTI_DEF_PROTO', defs, protos)
- end
- if other > 0 then
- lines[#lines+1] = lang.script('HOVER_MULTI_PROTO_NOT_FUNC', other)
- end
- if defs > 1 then
- for label, count in util.sortPairs(labels) do
- lines[#lines+1] = ('(%d) %s'):format(count, label)
+ if infer.searchAndViewInfers(source) == 'function' then
+ for _, def in ipairs(vm.getDefs(source)) do
+ if def.type == 'function'
+ or def.type == 'doc.type.function' then
+ addHover(def)
+ end
end
else
- lines[#lines+1] = next(labels)
- end
- local label = table.concat(lines, '\n')
- return {
- label = label,
- source = source,
- description = desc,
- }
-end
-
-local function getHoverAsDocName(source)
- local label = getLabel(source)
- local desc = getDesc(source)
- return {
- label = label,
- source = source,
- description = desc,
- }
-end
-
-local function isFunction(source)
- local defs = vm.getAllDefs(source)
- for _, def in ipairs(defs) do
- if def.type == 'function' then
- return true
+ addHover(source)
+ for _, def in ipairs(vm.getDefs(source)) do
+ addHover(def)
end
end
- return false
-end
-local function getHover(source)
- if source.type == 'doc.type.name' then
- return getHoverAsDocName(source)
- end
- if isFunction(source) then
- return getHoverAsFunction(source)
- else
- return getHoverAsValue(source)
- end
+ return md
end
local accept = {
@@ -168,14 +78,12 @@ local function getHoverByUri(uri, offset)
end
local hover = getHover(source)
if SHOWSOURCE then
- hover.description = ('%s\n---\n\n```lua\n%s\n```'):format(
- hover.description or '',
- util.dump(source, {
- deep = 1,
- })
- )
+ hover:splitLine()
+ hover:add('lua', util.dump(source, {
+ deep = 1,
+ }))
end
- return hover
+ return hover, source
end
return {
diff --git a/script/provider/markdown.lua b/script/provider/markdown.lua
index 140267d7..3a215f0f 100644
--- a/script/provider/markdown.lua
+++ b/script/provider/markdown.lua
@@ -15,6 +15,7 @@ function mt:add(language, text)
if not text then
return
end
+ self._cacheResult = nil
if type(text) == 'table' then
self[#self+1] = {
type = 'markdown',
@@ -34,12 +35,16 @@ function mt:add(language, text)
end
function mt:splitLine()
+ self._cacheResult = nil
self[#self+1] = {
type = 'splitline',
}
end
function mt:string()
+ if self._cacheResult then
+ return self._cacheResult
+ end
local lines = {}
local language = 'md'
@@ -97,7 +102,9 @@ function mt:string()
end
end
- return table.concat(lines, '\n')
+ local result = table.concat(lines, '\n')
+ self._cacheResult = result
+ return result
end
return function ()
diff --git a/script/provider/provider.lua b/script/provider/provider.lua
index 09a031cc..6ffb0837 100644
--- a/script/provider/provider.lua
+++ b/script/provider/provider.lua
@@ -186,20 +186,16 @@ proto.on('textDocument/hover', function (params)
return nil
end
local offset = files.offsetOfWord(uri, params.position)
- local hover = core.byUri(uri, offset)
+ local hover, source = core.byUri(uri, offset)
if not hover then
return nil
end
- local md = markdown()
- md:add('lua', hover.label)
- md:splitLine()
- md:add('md', hover.description)
return {
contents = {
- value = md:string(),
+ value = tostring(hover),
kind = 'markdown',
},
- range = files.range(uri, hover.source.start, hover.source.finish),
+ range = files.range(uri, source.start, source.finish),
}
end)