summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author最萌小汐 <sumneko@hotmail.com>2021-03-22 16:49:53 +0800
committer最萌小汐 <sumneko@hotmail.com>2021-03-22 16:49:53 +0800
commit76fc33156810722a1b4a8d821ca7aafc474250a2 (patch)
tree52d0ba7ce052c39d4192dd5c4f1a372cf55b7ab7
parent7bcee6ad40204b0f3632ed7b8024d6902afb2e73 (diff)
downloadlua-language-server-76fc33156810722a1b4a8d821ca7aafc474250a2.zip
add forward limit
-rw-r--r--script/core/guide.lua23
1 files changed, 15 insertions, 8 deletions
diff --git a/script/core/guide.lua b/script/core/guide.lua
index 9dc94390..9c0fac76 100644
--- a/script/core/guide.lua
+++ b/script/core/guide.lua
@@ -2254,6 +2254,9 @@ function m.checkSameSimpleInCall(status, ref, start, pushQueue, mode)
if status.share.inBeSetValue and status.share.inBeSetValue > 0 then
return
end
+ if status.share.inSetValue and status.share.inSetValue > 5 then
+ return
+ end
local func, args, index = m.getCallValue(ref)
if not func then
return
@@ -2261,14 +2264,9 @@ function m.checkSameSimpleInCall(status, ref, start, pushQueue, mode)
if m.checkCallMark(status, func.parent, true) then
return
end
- status.share.crossCallCount = status.share.crossCallCount or 0
+ status.share.inSetValue = (status.share.inSetValue or 0) + 1
-- 检查赋值是 semetatable() 的情况
m.checkSameSimpleInValueOfSetMetaTable(status, func, start, pushQueue)
- -- 检查赋值是 func() 的情况
- if status.share.crossCallCount >= 2 then
- --return
- end
- status.share.crossCallCount = status.share.crossCallCount + 1
local objs = m.checkSameSimpleInCallInSameFile(status, func, args, index)
if status.interface.call then
local cobjs = status.interface.call(func, args, index)
@@ -2304,7 +2302,7 @@ function m.checkSameSimpleInCall(status, ref, start, pushQueue, mode)
status.share.callFuncMark[obj] = nil
::CONTINUE::
end
- status.share.crossCallCount = status.share.crossCallCount - 1
+ status.share.inSetValue = (status.share.inSetValue or 0) - 1
end
local function searchRawset(ref, results)
@@ -2424,6 +2422,9 @@ function m.searchSameFieldsInValue(status, ref, start, pushQueue, mode)
if status.share.inBeSetValue and status.share.inBeSetValue > 0 then
return
end
+ if status.share.inSetValue and status.share.inSetValue > 5 then
+ return
+ end
local value = m.getObjectValue(ref)
if not value then
return
@@ -2507,6 +2508,9 @@ function m.checkSameSimpleAsSetValue(status, ref, start, pushQueue)
if status.share.inSetValue and status.share.inSetValue > 0 then
return
end
+ if status.share.inBeSetValue and status.share.inBeSetValue > 5 then
+ return
+ end
if ref.type == 'select' then
return
end
@@ -2658,6 +2662,9 @@ function m.checkSameSimpleAsCallArg(status, ref, start, pushQueue)
if (status.share.inSetValue or 0) > 0 then
return
end
+ if status.share.inBeSetValue and status.share.inBeSetValue > 5 then
+ return
+ end
status.share.inBeSetValue = (status.share.inBeSetValue or 0) + 1
local newStatus = m.status(status)
m.searchRefs(newStatus, call.node, 'def')
@@ -3078,7 +3085,7 @@ function m.searchSameFields(status, simple, mode)
-- break
--end
m.checkSameSimple(status, simple, obj, start, force, mode, pushQueue)
- if max >= 100000 then
+ if max >= 10000 then
logWarn('Queue too large!')
break
end