summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author最萌小汐 <sumneko@hotmail.com>2022-10-12 21:11:18 +0800
committer最萌小汐 <sumneko@hotmail.com>2022-10-12 21:11:18 +0800
commit7f04a46898cae87e57912a7e6b4739c61d74b18c (patch)
tree7fa0ff87c5407f2b0a835cc7a080e01e2760d1c1
parentb353856c94faa6ec76944f5dea70af3d31a77d14 (diff)
downloadlua-language-server-7f04a46898cae87e57912a7e6b4739c61d74b18c.zip
stash
-rw-r--r--script/core/diagnostics/missing-return-value.lua37
-rw-r--r--script/core/diagnostics/return-type-mismatch.lua14
-rw-r--r--test/diagnostics/type-check.lua37
3 files changed, 81 insertions, 7 deletions
diff --git a/script/core/diagnostics/missing-return-value.lua b/script/core/diagnostics/missing-return-value.lua
index 2156d66c..3aa7bd55 100644
--- a/script/core/diagnostics/missing-return-value.lua
+++ b/script/core/diagnostics/missing-return-value.lua
@@ -4,6 +4,7 @@ local vm = require 'vm'
local lang = require 'language'
local await = require 'await'
+---@param func parser.object
local function hasDocReturn(func)
if not func.bindDocs then
return false
@@ -12,10 +13,36 @@ local function hasDocReturn(func)
if doc.type == 'doc.return' then
return true
end
+ if doc.type == 'doc.overload' then
+ if #doc.overload.returns > 0 then
+ return true
+ end
+ end
end
return false
end
+---@param func parser.object
+---@return integer
+local function getReturnsMin(func)
+ local min = vm.countReturnsOfFunction(func)
+ if min == 0 then
+ return 0
+ end
+ for _, doc in ipairs(func.bindDocs) do
+ if doc.type == 'doc.overload' then
+ local n = vm.countReturnsOfFunction(doc.overload)
+ if n == 0 then
+ return 0
+ end
+ if n < min then
+ min = n
+ end
+ end
+ end
+ return min
+end
+
---@async
return function (uri, callback)
local state = files.getState(uri)
@@ -26,15 +53,15 @@ return function (uri, callback)
---@async
guide.eachSourceType(state.ast, 'function', function (source)
await.delay()
- if not hasDocReturn(source) then
+ local returns = source.returns
+ if not returns then
return
end
- local min = vm.countReturnsOfFunction(source)
- if min == 0 then
+ if not hasDocReturn(source) then
return
end
- local returns = source.returns
- if not returns then
+ local min = getReturnsMin(source)
+ if min == 0 then
return
end
for _, ret in ipairs(returns) do
diff --git a/script/core/diagnostics/return-type-mismatch.lua b/script/core/diagnostics/return-type-mismatch.lua
index cce4aad8..2ff8a909 100644
--- a/script/core/diagnostics/return-type-mismatch.lua
+++ b/script/core/diagnostics/return-type-mismatch.lua
@@ -3,6 +3,7 @@ local lang = require 'language'
local guide = require 'parser.guide'
local vm = require 'vm'
local await = require 'await'
+local util = require 'utility'
---@param func parser.object
---@return vm.node[]?
@@ -10,14 +11,23 @@ local function getDocReturns(func)
if not func.bindDocs then
return nil
end
- local returns = {}
+ ---@type table<integer, vm.node>
+ local returns = util.defaultTable(function ()
+ return vm.createNode()
+ end)
for _, doc in ipairs(func.bindDocs) do
if doc.type == 'doc.return' then
for _, ret in ipairs(doc.returns) do
- returns[ret.returnIndex] = vm.compileNode(ret)
+ returns[ret.returnIndex]:merge(vm.compileNode(ret))
+ end
+ end
+ if doc.type == 'doc.overload' then
+ for i, ret in ipairs(doc.overload.returns) do
+ returns[i]:merge(vm.compileNode(ret))
end
end
end
+ setmetatable(returns, nil)
if #returns == 0 then
return nil
end
diff --git a/test/diagnostics/type-check.lua b/test/diagnostics/type-check.lua
index 383527c2..5450eda4 100644
--- a/test/diagnostics/type-check.lua
+++ b/test/diagnostics/type-check.lua
@@ -784,6 +784,43 @@ local x
t[x] = true
]]
+TEST [[
+---@param x boolean
+---@return number
+---@overload fun(): boolean
+local function f(x)
+ if x then
+ return 1
+ else
+ return false
+ end
+end
+]]
+
+TEST [[
+---@param x boolean
+---@return number
+---@overload fun()
+local function f(x)
+ if x then
+ return 1
+ else
+ return
+ end
+end
+]]
+
+--TEST [[
+-----@param x boolean
+-----@return number
+-----@overload fun()
+--local function f(x)
+-- if x then
+-- return 1
+-- end
+--end
+--]]
+
config.remove(nil, 'Lua.diagnostics.disable', 'unused-local')
config.remove(nil, 'Lua.diagnostics.disable', 'unused-function')
config.remove(nil, 'Lua.diagnostics.disable', 'undefined-global')