From 4478a82397f2b5a60424fea894f5fd9dd3387b27 Mon Sep 17 00:00:00 2001 From: Hisham Muhammad Date: Fri, 5 Jan 2024 16:33:52 -0300 Subject: [PATCH] fix: preserve vararg info in recursive function definition Fixes #727 --- spec/call/function_spec.lua | 21 +++++++++++++++++++++ tl.lua | 2 +- tl.tl | 2 +- 3 files changed, 23 insertions(+), 2 deletions(-) diff --git a/spec/call/function_spec.lua b/spec/call/function_spec.lua index b3489b655..31f26b9e5 100644 --- a/spec/call/function_spec.lua +++ b/spec/call/function_spec.lua @@ -11,4 +11,25 @@ describe("function calls", function() ]], { { y = 6, msg = "variable is not being assigned a value" }, })) + + it("can perform recursive calls on varargs (regression test for #727)", util.check([[ + local message:string = "hello world!" + + local function foo(...: string): string + local n = select("#", ...) + if n < 3 then + return "" + end + if message ~= "hello world" then + return foo("hi there", select(2, ...)) + else + local r = {"hi there", select(2, ...)} + return foo(table.unpack(r)) + end + end + + local function bar(...: string): string + return foo("hi there", select(2, ...)) + end + ]])) end) diff --git a/tl.lua b/tl.lua index 3d1f2a76a..8d99203f0 100644 --- a/tl.lua +++ b/tl.lua @@ -7918,7 +7918,7 @@ tl.type_check = function(ast, opts) end local function add_function_definition_for_recursion(node) - local args = a_type({ typename = "tuple" }) + local args = a_type({ typename = "tuple", is_va = node.args.type.is_va }) for _, fnarg in ipairs(node.args) do table.insert(args, fnarg.type) end diff --git a/tl.tl b/tl.tl index 8291157c0..e0278f55e 100644 --- a/tl.tl +++ b/tl.tl @@ -7918,7 +7918,7 @@ tl.type_check = function(ast: Node, opts: TypeCheckOptions): Result, string end local function add_function_definition_for_recursion(node: Node) - local args: Type = a_type { typename = "tuple" } + local args: Type = a_type { typename = "tuple", is_va = node.args.type.is_va } for _, fnarg in ipairs(node.args) do table.insert(args, fnarg.type) end