From 60e400bf9b16219096f0f75ffcffbde0c27a84bd Mon Sep 17 00:00:00 2001 From: Alex Skorulis Date: Tue, 10 Dec 2024 14:56:40 +1100 Subject: [PATCH] Automatically make autoregister closures @escaping --- .../FunctionCallRegistrationParsing.swift | 13 +++++++++++-- .../KnitCodeGenTests/RegistrationParsingTests.swift | 2 +- 2 files changed, 12 insertions(+), 3 deletions(-) diff --git a/Sources/KnitCodeGen/FunctionCallRegistrationParsing.swift b/Sources/KnitCodeGen/FunctionCallRegistrationParsing.swift index eeb97d9..eac6c58 100644 --- a/Sources/KnitCodeGen/FunctionCallRegistrationParsing.swift +++ b/Sources/KnitCodeGen/FunctionCallRegistrationParsing.swift @@ -218,7 +218,12 @@ private func getArguments( if let argumentParam = arguments.first(where: {$0.label?.text == "argument"}), let argumentType = getArgumentType(arg: argumentParam) { - return [.init(type: argumentType)] + if TypeNamer.isClosure(type: argumentType) { + // Make all auto register closures @escaping + return [.init(type: "@escaping \(argumentType)")] + } else { + return [.init(type: argumentType)] + } } // Autoregister can provide multiple arguments. @@ -229,7 +234,11 @@ private func getArguments( guard let type = getArgumentType(arg: element) else { return nil } - return .init(type: type) + if TypeNamer.isClosure(type: type) { + return .init(type: "@escaping \(type)") + } else { + return .init(type: type) + } } } diff --git a/Tests/KnitCodeGenTests/RegistrationParsingTests.swift b/Tests/KnitCodeGenTests/RegistrationParsingTests.swift index f7f136f..3d72617 100644 --- a/Tests/KnitCodeGenTests/RegistrationParsingTests.swift +++ b/Tests/KnitCodeGenTests/RegistrationParsingTests.swift @@ -436,7 +436,7 @@ final class RegistrationParsingTests: XCTestCase { try assertMultipleRegistrationsString( "container.autoregister(A.self, argument: (() -> Void).self, initializer: A.init)", registrations: [ - Registration(service: "A", arguments: [.init(type: "(() -> Void)")], functionName: .autoregister), + Registration(service: "A", arguments: [.init(type: "@escaping (() -> Void)")], functionName: .autoregister), ] )