// Copyright 2009-2022 Josh Close // This file is a part of CsvHelper and is dual licensed under MS-PL and Apache 2.0. // See LICENSE.txt for details or visit http://www.opensource.org/licenses/ms-pl.html for MS-PL and http://opensource.org/licenses/Apache-2.0 for Apache 2.0. // https://github.com/JoshClose/CsvHelper using System.Collections; using System.Collections.Generic; using System.Linq; using CsvHelper.Configuration; namespace CsvHelper.TypeConversion { /// /// Converts an to and from a . /// public class IEnumerableGenericConverter : IEnumerableConverter { /// /// Converts the string to an object. /// /// The string to convert to an object. /// The for the current record. /// The for the member being created. /// The object created from the string. public override object? ConvertFromString(string? text, IReaderRow row, MemberMapData memberMapData) { var type = memberMapData.Member.MemberType().GetGenericArguments()[0]; var listType = typeof(List<>); listType = listType.MakeGenericType(type); var list = (IList)ObjectResolver.Current.Resolve(listType); var converter = row.Context.TypeConverterCache.GetConverter(type); if (memberMapData.IsNameSet || row.Configuration.HasHeaderRecord && !memberMapData.IsIndexSet) { // Use the name. var nameIndex = 0; while (true) { if (!row.TryGetField(type, memberMapData.Names.FirstOrDefault(), nameIndex, out var field)) { break; } list.Add(field); nameIndex++; } } else { // Use the index. var indexEnd = memberMapData.IndexEnd < memberMapData.Index ? row.Parser.Count - 1 : memberMapData.IndexEnd; for (var i = memberMapData.Index; i <= indexEnd; i++) { var field = converter.ConvertFromString(row.GetField(i), row, memberMapData); list.Add(field); } } return list; } } }