summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author最萌小汐 <sumneko@hotmail.com>2021-08-02 22:13:36 +0800
committer最萌小汐 <sumneko@hotmail.com>2021-08-02 22:13:36 +0800
commita6a37500fb306d5aaf14306f5aa7d00f86483133 (patch)
treeaff25d3e025fd2ddccac9e0eb7610c9c9ab378d9
parent2ddf4cd749b3fcbaba8123d074a790b4868fa1e1 (diff)
downloadlua-language-server-a6a37500fb306d5aaf14306f5aa7d00f86483133.zip
add cache
-rw-r--r--script/core/searcher.lua42
-rw-r--r--test/full/example.lua2
2 files changed, 35 insertions, 9 deletions
diff --git a/script/core/searcher.lua b/script/core/searcher.lua
index 777da050..b246094c 100644
--- a/script/core/searcher.lua
+++ b/script/core/searcher.lua
@@ -284,8 +284,15 @@ local function checkCache(status, uri, expect, mode)
end
return true
end
- fileCache[expect] = status.results
- return false
+ return false, function ()
+ fileCache[expect] = status.results
+ if mode == 'def' then
+ return
+ end
+ for id in pairs(status.ids) do
+ fileCache[id] = status.results
+ end
+ end
end
local function stop(status, msg)
@@ -387,6 +394,13 @@ function m.searchRefsByID(status, uri, expect, mode)
status.elock[uri] = elock
local function search(id, field)
+ if not field then
+ local cached = checkCache(status, uri, id, mode)
+ if cached then
+ return
+ end
+ status.ids[id] = true
+ end
local firstID = noder.getFirstID(id)
if ignoredIDs[firstID] and (field or firstID ~= id) then
return
@@ -1019,7 +1033,9 @@ function m.searchRefs(status, source, mode)
return
end
- if checkCache(status, uri, id, mode) then
+ local cached, makeCache = checkCache(status, uri, id, mode)
+
+ if cached then
return
end
@@ -1027,6 +1043,7 @@ function m.searchRefs(status, source, mode)
log.debug('searchRefs:', id)
end
m.searchRefsByID(status, uri, id, mode)
+ makeCache()
end
---搜索对象的field
@@ -1044,12 +1061,15 @@ function m.searchFields(status, source, mode, field)
end
if field == '*' then
if source.special == '_G' then
- if checkCache(status, uri, '*', mode) then
+ local cached, makeCache = checkCache(status, uri, '*', mode)
+ if cached then
return
end
searchAllGlobals(status, mode)
+ makeCache()
else
- if checkCache(status, uri, id .. '*', mode) then
+ local cached, makeCache = checkCache(status, uri, id .. '*', mode)
+ if cached then
return
end
local newStatus = m.status('field')
@@ -1057,6 +1077,7 @@ function m.searchFields(status, source, mode, field)
for _, def in ipairs(newStatus.results) do
getField(status, def, mode)
end
+ makeCache()
end
else
if source.special == '_G' then
@@ -1066,10 +1087,12 @@ function m.searchFields(status, source, mode, field)
else
fullID = sformat('%s%s%s', 'g:', '', field)
end
- if checkCache(status, uri, fullID, mode) then
+ local cahced, makeCache = checkCache(status, uri, fullID, mode)
+ if cahced then
return
end
m.searchRefsByID(status, uri, fullID, mode)
+ makeCache()
else
local fullID
if type(field) == 'string' then
@@ -1077,10 +1100,12 @@ function m.searchFields(status, source, mode, field)
else
fullID = sformat('%s%s%s', id, noder.SPLIT_CHAR, field)
end
- if checkCache(status, uri, fullID, mode) then
+ local cahced, makeCache = checkCache(status, uri, fullID, mode)
+ if cahced then
return
end
m.searchRefsByID(status, uri, fullID, mode)
+ makeCache()
end
end
end
@@ -1106,11 +1131,12 @@ function m.status(mode)
smark = {},
footprint = {},
count = 0,
+ ids = {},
ftag = {},
btag = {},
dontCross = 0,
mode = mode,
- cache = vm.getCache('searcher:' .. mode)
+ cache = vm.getCache('searcher:' .. mode),
}
return status
end
diff --git a/test/full/example.lua b/test/full/example.lua
index a33c9385..38e649eb 100644
--- a/test/full/example.lua
+++ b/test/full/example.lua
@@ -15,7 +15,7 @@ local function testIfExit(path)
local vm
local clock = os.clock()
- local max = 100
+ local max = 1
local need
local parseClock = 0
local compileClock = 0