diff options
author | 最萌小汐 <sumneko@hotmail.com> | 2022-10-12 21:11:18 +0800 |
---|---|---|
committer | 最萌小汐 <sumneko@hotmail.com> | 2022-10-12 21:11:18 +0800 |
commit | 7f04a46898cae87e57912a7e6b4739c61d74b18c (patch) | |
tree | 7fa0ff87c5407f2b0a835cc7a080e01e2760d1c1 | |
parent | b353856c94faa6ec76944f5dea70af3d31a77d14 (diff) | |
download | lua-language-server-7f04a46898cae87e57912a7e6b4739c61d74b18c.zip |
stash
-rw-r--r-- | script/core/diagnostics/missing-return-value.lua | 37 | ||||
-rw-r--r-- | script/core/diagnostics/return-type-mismatch.lua | 14 | ||||
-rw-r--r-- | test/diagnostics/type-check.lua | 37 |
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') |