summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author最萌小汐 <sumneko@hotmail.com>2021-04-25 17:32:25 +0800
committer最萌小汐 <sumneko@hotmail.com>2021-04-25 17:32:25 +0800
commit9841a6b601e93517c61e09ec27a48ebc39564cc0 (patch)
tree990fd856c80c38e6ae24462200bbb4aa4b632235
parent8c2828b209f30c95eadd7422882faf6ccc717069 (diff)
downloadlua-language-server-9841a6b601e93517c61e09ec27a48ebc39564cc0.zip
stash
-rw-r--r--script/core/linker.lua63
-rw-r--r--script/core/searcher.lua2
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