diff options
author | 最萌小汐 <sumneko@hotmail.com> | 2022-11-03 15:24:32 +0800 |
---|---|---|
committer | 最萌小汐 <sumneko@hotmail.com> | 2022-11-03 15:24:32 +0800 |
commit | 213f5176ff3125feab1e743ef57abba0e18a44a5 (patch) | |
tree | ebf8d225bfd3bc041e3614ce546a85a7bf833492 /script | |
parent | b04dee92ee20fb4548c5f941af3ea40603828fac (diff) | |
download | lua-language-server-213f5176ff3125feab1e743ef57abba0e18a44a5.zip |
supports completion with table field of function
resolve #1533
Diffstat (limited to 'script')
-rw-r--r-- | script/core/completion/completion.lua | 63 |
1 files changed, 31 insertions, 32 deletions
diff --git a/script/core/completion/completion.lua b/script/core/completion/completion.lua index 0f85bec5..5b92a3c1 100644 --- a/script/core/completion/completion.lua +++ b/script/core/completion/completion.lua @@ -1199,6 +1199,17 @@ local function insertDocEnum(state, pos, doc, enums) return enums end +local function buildInsertDocFunction(doc) + local args = {} + for i, arg in ipairs(doc.args) do + args[i] = ('${%d:%s}'):format(i, arg.name[1]) + end + return ("\z +function (%s)\ +\t$0\ +end"):format(table.concat(args, ', ')) +end + ---@param state parser.state ---@param pos integer ---@param src vm.node.object @@ -1220,6 +1231,26 @@ local function insertEnum(state, pos, src, enums, isInArray) description = src.comment, kind = define.CompletionItemKind.EnumMember, } + elseif src.type == 'doc.type.function' then + ---@cast src parser.object + local insertText = buildInsertDocFunction(src) + local description + if src.comment then + description = src.comment + else + local descText = insertText:gsub('%$%{%d+:([^}]+)%}', function (val) + return val + end):gsub('%$%{?%d+%}?', '') + description = markdown() + : add('lua', descText) + : string() + end + enums[#enums+1] = { + label = vm.getInfer(src):view(state.uri), + description = description, + kind = define.CompletionItemKind.Function, + insertText = insertText, + } elseif isInArray and src.type == 'doc.type.array' then for i, d in ipairs(vm.getDefs(src.node)) do insertEnum(state, pos, d, enums, isInArray) @@ -1433,17 +1464,6 @@ local function trySymbol(state, position, results) end end -local function buildInsertDocFunction(doc) - local args = {} - for i, arg in ipairs(doc.args) do - args[i] = ('${%d:%s}'):format(i, arg.name[1]) - end - return ("\z -function (%s)\ -\t$0\ -end"):format(table.concat(args, ', ')) -end - local function findCall(state, position) local call guide.eachSourceContain(state.ast, position, function (src) @@ -1534,27 +1554,6 @@ local function tryCallArg(state, position, results) local enums = {} for src in node:eachObject() do insertEnum(state, position, src, enums, arg and arg.type == 'table') - if src.type == 'doc.type.function' then - ---@cast src parser.object - local insertText = buildInsertDocFunction(src) - local description - if src.comment then - description = src.comment - else - local descText = insertText:gsub('%$%{%d+:([^}]+)%}', function (val) - return val - end):gsub('%$%{?%d+%}?', '') - description = markdown() - : add('lua', descText) - : string() - end - enums[#enums+1] = { - label = vm.getInfer(src):view(state.uri), - description = description, - kind = define.CompletionItemKind.Function, - insertText = insertText, - } - end end cleanEnums(enums, arg) for _, enum in ipairs(enums) do |