// 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 IEnumerableConverter : DefaultTypeConverter { /// /// Converts the object to a string. /// /// The object to convert to a string. /// /// /// The string representation of the object. public override string? ConvertToString(object? value, IWriterRow row, MemberMapData memberMapData) { var list = value as IEnumerable; if (list == null) { return base.ConvertToString(value, row, memberMapData); } foreach (var item in list) { row.WriteField(item.ToString()); } return null; } /// /// 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 list = new List(); if (memberMapData.IsNameSet || row.Configuration.HasHeaderRecord && !memberMapData.IsIndexSet) { // Use the name. var nameIndex = 0; while (true) { if (!row.TryGetField(memberMapData.Names.FirstOrDefault(), nameIndex, out string 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++) { if (row.TryGetField(i, out string field)) { list.Add(field); } } } return list; } } }