From 05b8cf4e0f92798c08aceb74891de5fb025ae1fb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=9C=80=E8=90=8C=E5=B0=8F=E6=B1=90?= Date: Fri, 17 Jun 2022 15:51:03 +0800 Subject: fix #1223 count returns of `doc.type.function` --- changelog.md | 1 + script/core/diagnostics/missing-parameter.lua | 19 +++++++++++++++---- test/diagnostics/common.lua | 12 ++++++++++++ 3 files changed, 28 insertions(+), 4 deletions(-) diff --git a/changelog.md b/changelog.md index 436370c9..1803c901 100644 --- a/changelog.md +++ b/changelog.md @@ -6,6 +6,7 @@ * `FIX` [#1217](https://github.com/sumneko/lua-language-server/issues/1217) * `FIX` [#1218](https://github.com/sumneko/lua-language-server/issues/1218) * `FIX` [#1220](https://github.com/sumneko/lua-language-server/issues/1220) +* `FIX` [#1223](https://github.com/sumneko/lua-language-server/issues/1223) ## 3.3.0 `2022-6-15` diff --git a/script/core/diagnostics/missing-parameter.lua b/script/core/diagnostics/missing-parameter.lua index a475673f..9844046f 100644 --- a/script/core/diagnostics/missing-parameter.lua +++ b/script/core/diagnostics/missing-parameter.lua @@ -5,7 +5,7 @@ local lang = require 'language' ---@param source parser.object ---@return integer -local function countReturns(source) +local function countReturnsOfFunction(source) local n = 0 local docs = source.bindDocs @@ -33,14 +33,25 @@ local function countReturns(source) return n end +---@param source parser.object +---@return integer +local function countReturnsOfDocFunction(source) + return #source.returns +end + local function countMaxReturns(source) local hasFounded local n = 0 for _, def in ipairs(vm.getDefs(source)) do - if def.type == 'doc.type.function' - or def.type == 'function' then + if def.type == 'function' then + hasFounded = true + local rets = countReturnsOfFunction(def) + if rets > n then + n = rets + end + elseif def.type == 'doc.type.function' then hasFounded = true - local rets = countReturns(def) + local rets = countReturnsOfDocFunction(def) if rets > n then n = rets end diff --git a/test/diagnostics/common.lua b/test/diagnostics/common.lua index 428d8a45..53186198 100644 --- a/test/diagnostics/common.lua +++ b/test/diagnostics/common.lua @@ -1601,3 +1601,15 @@ end f1(f2()) ]] + +TEST [[ +---@meta + +---@type fun():integer +local f + +---@param x integer +local function foo(x) end + +foo(f()) +]] -- cgit v1.2.3