diff options
author | 最萌小汐 <sumneko@hotmail.com> | 2021-04-25 17:32:25 +0800 |
---|---|---|
committer | 最萌小汐 <sumneko@hotmail.com> | 2021-04-25 17:32:25 +0800 |
commit | 9841a6b601e93517c61e09ec27a48ebc39564cc0 (patch) | |
tree | 990fd856c80c38e6ae24462200bbb4aa4b632235 | |
parent | 8c2828b209f30c95eadd7422882faf6ccc717069 (diff) | |
download | lua-language-server-9841a6b601e93517c61e09ec27a48ebc39564cc0.zip |
stash
-rw-r--r-- | script/core/linker.lua | 63 | ||||
-rw-r--r-- | script/core/searcher.lua | 2 |
2 files changed, 61 insertions, 4 deletions
diff --git a/script/core/linker.lua b/script/core/linker.lua index 241064be..9741d7b4 100644 --- a/script/core/linker.lua +++ b/script/core/linker.lua @@ -1,8 +1,5 @@ local util = require 'utility' local guide = require 'parser.guide' -local vm = require 'vm.vm' -local split = require "parser.split" -local telemetry = require "service.telemetry" local Linkers, GetLink local LastIDCache = {} @@ -83,6 +80,8 @@ local function getKey(source) return nil, nil elseif source.type == 'function' then return source.start, nil + elseif source.type == '...' then + return source.start, nil elseif source.type == 'select' then return ('%d%s%s%d'):format(source.start, SPLIT_CHAR, RETURN_INDEX_CHAR, source.index) elseif source.type == 'call' then @@ -106,14 +105,19 @@ local function getKey(source) elseif source.type == 'doc.class.name' or source.type == 'doc.type.name' or source.type == 'doc.alias.name' - or source.type == 'doc.extends.name' then + or source.type == 'doc.extends.name' + or source.type == 'doc.see.name' then return source[1], nil elseif source.type == 'doc.class' or source.type == 'doc.type' or source.type == 'doc.alias' or source.type == 'doc.param' + or source.type == 'doc.vararg' + or source.type == 'doc.field.name' or source.type == 'doc.type.function' then return source.start, nil + elseif source.type == 'doc.see.field' then + return ('%q'):format(source[1]), source.parent.name end return nil, nil end @@ -137,6 +141,12 @@ local function checkMode(source) or source.type == 'doc.extends.name' then return 'dn:' end + if source.type == 'doc.field.name' then + return 'dfn:' + end + if source.type == 'doc.see.name' then + return 'dsn:' + end if source.type == 'doc.class' then return 'dc:' end @@ -152,6 +162,9 @@ local function checkMode(source) if source.type == 'doc.type.function' then return 'df:' end + if source.type == 'doc.vararg' then + return 'dv:' + end if isGlobal(source) then return 'g:' end @@ -326,10 +339,45 @@ local function compileLink(source) pushForward(id, getID(src)) end end + do + local start + for _, doc in ipairs(source.bindGroup) do + if doc.type == 'doc.class' then + start = doc == source + end + if start and doc.type == 'doc.field' then + local key = doc.field[1] + if key then + local keyID = ('%s%s%q'):format( + id, + SPLIT_CHAR, + key + ) + pushForward(keyID, getID(doc.field)) + pushBackward(getID(doc.field), keyID) + pushForward(keyID, getID(doc.extends)) + pushBackward(getID(doc.extends), keyID) + end + end + end + end end if source.type == 'doc.param' then pushForward(getID(source), getID(source.extends)) end + if source.type == 'doc.vararg' then + pushForward(getID(source), getID(source.vararg)) + end + if source.type == 'doc.see' then + local nameID = getID(source.name) + local classID = nameID:gsub('^dsn:', 'dn:') + pushForward(nameID, classID) + if source.field then + local fieldID = getID(source.field) + local fieldClassID = fieldID:gsub('^dsn:', 'dn:') + pushForward(fieldID, fieldClassID) + end + end if source.type == 'call' then local node = source.node local nodeID = getID(node) @@ -427,6 +475,13 @@ local function compileLink(source) end end end + if doc.type == 'doc.vararg' then + for _, param in ipairs(source.args) do + if param.type == '...' then + pushForward(getID(param), getID(doc)) + end + end + end end end end diff --git a/script/core/searcher.lua b/script/core/searcher.lua index 69221436..ede0178c 100644 --- a/script/core/searcher.lua +++ b/script/core/searcher.lua @@ -47,6 +47,7 @@ function m.pushResult(status, mode, source) or source.type == 'function' or source.type == 'doc.class.name' or source.type == 'doc.alias.name' + or source.type == 'doc.field.name' or source.type == 'doc.type.function' then results[#results+1] = source end @@ -81,6 +82,7 @@ function m.pushResult(status, mode, source) or source.type == 'doc.type.name' or source.type == 'doc.alias.name' or source.type == 'doc.extends.name' + or source.type == 'doc.field.name' or source.type == 'doc.type.function' then results[#results+1] = source end |