summaryrefslogtreecommitdiff
path: root/script/vm/tracer.lua
diff options
context:
space:
mode:
author最萌小汐 <sumneko@hotmail.com>2022-12-16 03:35:08 +0800
committer最萌小汐 <sumneko@hotmail.com>2022-12-16 03:35:08 +0800
commit664a5c78ade155d99543c94d3f63b98b4d0df82d (patch)
tree5bb859bff2be4c42ab6be4dbe685e347781c7e09 /script/vm/tracer.lua
parent420197c19e223cf1c3ce33534abb38bba304896b (diff)
downloadlua-language-server-664a5c78ade155d99543c94d3f63b98b4d0df82d.zip
fix cast
Diffstat (limited to 'script/vm/tracer.lua')
-rw-r--r--script/vm/tracer.lua83
1 files changed, 54 insertions, 29 deletions
diff --git a/script/vm/tracer.lua b/script/vm/tracer.lua
index 85a0faa7..cbd7d855 100644
--- a/script/vm/tracer.lua
+++ b/script/vm/tracer.lua
@@ -202,7 +202,7 @@ function mt:lookIntoChild(action, topNode, outNode)
end
end
elseif action.type == 'function' then
- self:lookIntoBlock(action, 0, topNode:copy())
+ self:lookIntoBlock(action, action.args.finish, topNode:copy())
elseif action.type == 'unary' then
if not action[1] then
goto RETURN
@@ -312,12 +312,24 @@ function mt:lookIntoChild(action, topNode, outNode)
or action.type == 'repeat'
or action.type == 'for'
or action.type == 'do' then
- self:lookIntoBlock(action, 0, topNode:copy())
- local lastAssign = self:getLastAssign(action.start, action.finish)
- if lastAssign then
- local node = self:getNode(lastAssign)
- if node then
- topNode = node:copy()
+ if action[1] then
+ local actionStart
+ if action.type == 'loop' then
+ actionStart = action.keyword[4]
+ elseif action.type == 'in' then
+ actionStart = action.keyword[6]
+ elseif action.type == 'repeat'
+ or action.type == 'for'
+ or action.type == 'do' then
+ actionStart = action.keyword[2]
+ end
+ self:lookIntoBlock(action, actionStart, topNode:copy())
+ local lastAssign = self:getLastAssign(action.start, action.finish)
+ if lastAssign then
+ local node = self:getNode(lastAssign)
+ if node then
+ topNode = node:copy()
+ end
end
end
elseif action.type == 'while' then
@@ -328,12 +340,14 @@ function mt:lookIntoChild(action, topNode, outNode)
blockNode = topNode:copy()
mainNode = topNode:copy()
end
- self:lookIntoBlock(action, 0, blockNode:copy())
- local lastAssign = self:getLastAssign(action.start, action.finish)
- if lastAssign then
- local node = self:getNode(lastAssign)
- if node then
- topNode = mainNode:merge(node)
+ if action[1] then
+ self:lookIntoBlock(action, action.keyword[4], blockNode:copy())
+ local lastAssign = self:getLastAssign(action.start, action.finish)
+ if lastAssign then
+ local node = self:getNode(lastAssign)
+ if node then
+ topNode = mainNode:merge(node)
+ end
end
end
if action.filter then
@@ -355,25 +369,36 @@ function mt:lookIntoChild(action, topNode, outNode)
hasElse = true
mainNode:clear()
end
- self:lookIntoBlock(subBlock, 0, blockNode:copy())
- local neverReturn = subBlock.hasReturn
- or subBlock.hasGoTo
- or subBlock.hasBreak
- or subBlock.hasError
- if not neverReturn then
- local ok
- local lastAssign = self:getLastAssign(subBlock.start, subBlock.finish)
- if lastAssign then
- local node = self:getNode(lastAssign)
- if node then
- blockNodes[#blockNodes+1] = node
- ok = true
- end
+ local mergedNode
+ if subBlock[1] then
+ local actionStart
+ if subBlock.type == 'ifblock'
+ or subBlock.type == 'elseif' then
+ actionStart = subBlock.keyword[4]
+ else
+ actionStart = subBlock.keyword[2]
end
- if not ok then
- blockNodes[#blockNodes+1] = blockNode
+ self:lookIntoBlock(subBlock, actionStart, blockNode:copy())
+ local neverReturn = subBlock.hasReturn
+ or subBlock.hasGoTo
+ or subBlock.hasBreak
+ or subBlock.hasError
+ if neverReturn then
+ mergedNode = true
+ else
+ local lastAssign = self:getLastAssign(subBlock.start, subBlock.finish)
+ if lastAssign then
+ local node = self:getNode(lastAssign)
+ if node then
+ blockNodes[#blockNodes+1] = node
+ mergedNode = true
+ end
+ end
end
end
+ if not mergedNode then
+ blockNodes[#blockNodes+1] = blockNode
+ end
end
if not hasElse and not topNode:hasKnownType() then
mainNode:merge(vm.declareGlobal('type', 'unknown'))