From 972e6458ed5c256cb3d1de05b585bc3fc55f82ad Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=9C=80=E8=90=8C=E5=B0=8F=E6=B1=90?= Date: Tue, 27 Aug 2019 20:54:07 +0800 Subject: =?UTF-8?q?=E5=88=86=E7=A6=BB=E5=87=BD=E6=95=B0=E8=B0=83=E7=94=A8?= =?UTF-8?q?=E4=B8=8E=E5=87=BD=E6=95=B0=E5=AF=B9=E8=B1=A1?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- server/src/core/completion.lua | 87 +++++++++++++++++++++--------------------- 1 file changed, 43 insertions(+), 44 deletions(-) (limited to 'server/src/core') diff --git a/server/src/core/completion.lua b/server/src/core/completion.lua index a3994833..b9191568 100644 --- a/server/src/core/completion.lua +++ b/server/src/core/completion.lua @@ -153,11 +153,45 @@ local function getKind(cata, value) return nil end +local function buildSnipArgs(args) + local t = {} + for i, name in ipairs(args) do + t[i] = ('${%d:%s}'):format(i, name) + end + return table.concat(t, ', ') +end + +local function getFunctionSnip(name, value) + if value:getType() ~= 'function' then + return + end + local lib = value:getLib() + local hover + if lib then + hover = getFunctionHoverAsLib(name, lib) + else + local emmy = value:getEmmy() + if emmy and emmy.type == 'emmy.functionType' then + hover = getFunctionHoverAsEmmy(name, emmy) + else + hover = getFunctionHover(name, value:getFunction()) + end + end + if not hover then + return ('%s()'):format(name) + end + if not hover.args then + return ('%s()'):format(name) + end + return ('%s(%s)'):format(name, buildSnipArgs(hover.args)) +end + local function getValueData(cata, name, value, pos, source) local data = { documentation = getDucumentation(name, value), detail = getDetail(value), kind = getKind(cata, value), + snip = getFunctionSnip(name, value), } if cata == 'field' then if not parser:grammar(name, 'Name') then @@ -869,49 +903,6 @@ local function searchSpecial(vm, source, word, callback, pos, text) searchSpecialHashSign(vm, pos, text, callback) end -local function buildSnipArgs(args) - local t = {} - for i, name in ipairs(args) do - t[i] = ('${%d:%s}'):format(i, name) - end - return table.concat(t, ', ') -end - -local function makeFunctionSnippet(src, data) - if not src then - return - end - local value = src:findValue() - if not value then - return - end - local func = value:getFunction() - if not func then - return - end - local name = data.label - local lib = value:getLib() - local hover - if lib then - hover = getFunctionHoverAsLib(name, lib) - else - local emmy = value:getEmmy() - if emmy and emmy.type == 'emmy.functionType' then - hover = getFunctionHoverAsEmmy(name, emmy) - else - hover = getFunctionHover(name, value:getFunction()) - end - end - if not hover then - return - end - if not hover.args then - return - end - data.insertTextFormat = 2 - data.insertText = ('%s(%s)'):format(data.label, buildSnipArgs(hover.args)) -end - local function makeList(source, pos, word) local list = {} local mark = {} @@ -937,8 +928,16 @@ local function makeList(source, pos, word) if not data.kind then data.kind = kind end - makeFunctionSnippet(src, data) list[#list+1] = data + if data.snip then + local snipData = table.deepCopy(data) + snipData.insertText = data.snip + snipData.kind = CompletionItemKind.Snippet + snipData.label = snipData.label .. '()' + snipData.snip = nil + data.snip = nil + list[#list+1] = snipData + end end, list end -- cgit v1.2.3