From f3d482c98cd756dc3ed7b80cb712d11ec9940dfe Mon Sep 17 00:00:00 2001 From: Maksim Levental Date: Thu, 2 May 2019 09:47:53 -0400 Subject: [PATCH] implement transformation of header --- Frameworks/CSVImporter/CSVImporter.swift | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) diff --git a/Frameworks/CSVImporter/CSVImporter.swift b/Frameworks/CSVImporter/CSVImporter.swift index 9cb5543..510b779 100644 --- a/Frameworks/CSVImporter/CSVImporter.swift +++ b/Frameworks/CSVImporter/CSVImporter.swift @@ -176,7 +176,7 @@ public class CSVImporter { /// - recordMapper: A closure to map the dictionary data interpreted from a line to your data structure. /// - Returns: `self` to enable consecutive method calls (e.g. `importer.startImportingRecords {...}.onProgress {...}`). public func startImportingRecords( - structure structureClosure: @escaping (_ headerValues: [String]) -> Void, + structure structureClosure: @escaping (_ headerValues: [String]) -> [String], recordMapper closure: @escaping (_ recordValues: [String: String]) -> T ) -> Self { workDispatchQueue.async { @@ -185,8 +185,7 @@ public class CSVImporter { let importedLinesWithSuccess = self.importLines { valuesInLine in if recordStructure == nil { - recordStructure = valuesInLine - structureClosure(valuesInLine) + recordStructure = structureClosure(valuesInLine) } else { if let structuredValuesInLine = [String: String](keys: recordStructure!, values: valuesInLine) { let newRecord = closure(structuredValuesInLine) @@ -235,7 +234,7 @@ public class CSVImporter { /// - recordMapper: A closure to map the dictionary data interpreted from a line to your data structure. /// - Returns: The imported records array. public func importRecords( - structure structureClosure: @escaping (_ headerValues: [String]) -> Void, + structure structureClosure: @escaping (_ headerValues: [String]) -> [String], recordMapper closure: @escaping (_ recordValues: [String: String]) -> T ) -> [T] { var recordStructure: [String]? @@ -243,8 +242,7 @@ public class CSVImporter { _ = self.importLines { valuesInLine in if recordStructure == nil { - recordStructure = valuesInLine - structureClosure(valuesInLine) + recordStructure = structureClosure(valuesInLine) } else { if let structuredValuesInLine = [String: String](keys: recordStructure!, values: valuesInLine) { let newRecord = closure(structuredValuesInLine)